PHPackages                             axiostudio/fattura-elettronica - PHPackages - PHPackages  [Skip to content](#main-content)[PHPackages](/)[Directory](/)[Categories](/categories)[Trending](/trending)[Leaderboard](/leaderboard)[Changelog](/changelog)[Analyze](/analyze)[Collections](/collections)[Log in](/login)[Sign up](/register)

1. [Directory](/)
2. /
3. [Parsing &amp; Serialization](/categories/parsing)
4. /
5. axiostudio/fattura-elettronica

ActiveLibrary[Parsing &amp; Serialization](/categories/parsing)

axiostudio/fattura-elettronica
==============================

Pacchetto per la gestione della fatturazione elettronica in PHP.

1.0.7(2y ago)3781MITPHPPHP ^8.1|^8.2|^8.3

Since Nov 14Pushed 2y ago2 watchersCompare

[ Source](https://github.com/axiostudio/fattura-elettronica)[ Packagist](https://packagist.org/packages/axiostudio/fattura-elettronica)[ Docs](https://github.com/axiostudio/fattura-elettronica)[ RSS](/packages/axiostudio-fattura-elettronica/feed)WikiDiscussions master Synced 1mo ago

READMEChangelog (9)Dependencies (4)Versions (11)Used By (0)

Fattura Elettronica PHP
=======================

[](#fattura-elettronica-php)

[![Latest Version on Packagist](https://camo.githubusercontent.com/14b31963763e2e0ae5b2aa27b285c7d95393f0f0fa1de1c444a94ba86b787a63/68747470733a2f2f696d672e736869656c64732e696f2f7061636b61676973742f762f6178696f73747564696f2f666174747572612d656c657474726f6e6963612e7376673f7374796c653d666c61742d737175617265)](https://packagist.org/packages/axiostudio/fattura-elettronica)[![Tests](https://github.com/axiostudio/fattura-elettronica/actions/workflows/tests.yml/badge.svg)](https://github.com/axiostudio/fattura-elettronica/actions/workflows/tests.yml)[![Total Downloads](https://camo.githubusercontent.com/0de66397cc7e0f90ed63a4d6c9b7319731aaab77968a7cb69ce6dfd513aff78b/68747470733a2f2f696d672e736869656c64732e696f2f7061636b61676973742f64742f6178696f73747564696f2f666174747572612d656c657474726f6e6963612e7376673f7374796c653d666c61742d737175617265)](https://packagist.org/packages/axiostudio/fattura-elettronica)

Introduzione
------------

[](#introduzione)

Fattura Elettronica è un pacchetto PHP che consente di generare all'interno del proprio applicativo, fatture elettroniche in XML compatibili con le seguenti specifiche:

Requisiti
---------

[](#requisiti)

- Composer 2
- PHP (dalla versione 8.1 in poi)

Installazione
-------------

[](#installazione)

Per installare il pacchetto eseguire:

```
composer require axiostudio/fattura-elettronica
```

Utilizzo
--------

[](#utilizzo)

Finita l'installazione, per utilizzare il pacchetto è necessario inizializzare la classe:

```
$fattura = new \Axiostudio\FatturaElettronica\FatturaElettronica();
```

Successivamente bisogna passare i dati necessari al metodo "compose" che ci restituirà un array contente un parametro `fileName` che dichiara il nome del file XML generato e un parametro `fileContent` che contiene in formato string l'XML generato.

Per generare la fattura è necessario richiamare il metodo `compose()` passando al suo interno i dati necessari alla fattura che saranno parsati, computati e convertiti in formato XML secondo le specifiche.

La funzione "compose" necessita dei seguenti oggetti, nel seguente ordine per comporre la fattura:

- $datiTrasmissione,
- $anagraficaPrestatore,
- $sedePrestatore,
- $anagraficaCommittente,
- $sedeCommittente,
- $datiGenerali,
- $datiDatiPagamento,
- $dettaglioLinee,
- $datiRiepilogo

Ogni oggetto ha una specifica struct con dati obbligatori e dati opzionali. Di seguito la descrizione di essi:

#### DatiAnagrafici

[](#datianagrafici)

```
public Id $IdFiscaleIVA;
public Anagrafica $Anagrafica;
public ?string $CodiceFiscale;
public ?string $RegimeFiscale;

```

#### Id

[](#id)

```
public string $IdCodice;
public ?string $IdPaese;

```

#### Anagrafica

[](#anagrafica)

```
public ?string $Denominazione;
public ?string $Nome;
public ?string $Cognome;

```

#### Sede

[](#sede)

```
public string $Indirizzo;
public string $CAP;
public string $Comune;
public ?string $Provincia;
public ?string $Nazione;

```

#### DatiGeneraliDocumento

[](#datigeneralidocumento)

```
public string $Numero;
public string $Data;
public float $ImportoTotaleDocumento;
public ?string $Causale;
public ?string $TipoDocumento;
public ?string $Divisa;

```

#### DatiPagamento

[](#datipagamento)

```
public DettaglioPagamento $DettaglioPagamento;
public ?string $CondizioniPagamento;

```

#### DettaglioPagamento

[](#dettagliopagamento)

```
public float $ImportoPagamento;
public ?string $DataScadenzaPagamento;
public ?string $DataRiferimentoTerminiPagamento;
public ?string $GiorniTerminiPagamento;
public ?string $Beneficiario;
public ?string $IstitutoFinanziario;
public ?string $IBAN;
public ?string $ABI;
public ?string $CAB;
public ?string $BIC;
public ?string $ModalitaPagamento;

```

#### DatiRiepilogo

[](#datiriepilogo)

```
public float $ImponibileImporto;
public float $AliquotaIVA;
public ?string $Natura;
public ?string $EsigibilitaIVA;
public float $Imposta;

```

#### DatiTrasmissione

[](#datitrasmissione)

```
public Id $IdTrasmittente;
public string $ProgressivoInvio;
public ?string $CodiceDestinatario;
public ?string $PECDestinatario;
public ?string $FormatoTrasmissione;

```

#### DettaglioLinee

[](#dettagliolinee)

```
public string $Descrizione;
public float $PrezzoUnitario;
public ?float $Quantita;
public ?string $UnitaMisura;
public ?float $AliquotaIVA;
public ?string $Natura;
public ?float $PrezzoTotale;

```

#### DettaglioPagamento

[](#dettagliopagamento-1)

```
public float $ImportoPagamento;
public ?string $DataScadenzaPagamento;
public ?string $DataRiferimentoTerminiPagamento;
public ?string $GiorniTerminiPagamento;
public ?string $Beneficiario;
public ?string $IstitutoFinanziario;
public ?string $IBAN;
public ?string $ABI;
public ?string $CAB;
public ?string $BIC;
public ?string $ModalitaPagamento;

```

### Inizializzazione di una nuova fattura

[](#inizializzazione-di-una-nuova-fattura)

Per inizializzare una fattura avremo quindi una struct di questo tipo:

```
$datiXml = $fattura->compose(
    $datiTrasmissione, // DatiTrasmissione
    $anagraficaPrestatore,  // DatiAnagrafici
    $sedePrestatore, // Sede
    $anagraficaCommittente, // DatiAnagrafici
    $sedeCommittente, // Sede
    $datiGenerali, // DatiGeneraliDocumento
    $datiDatiPagamento, // DatiPagamento
    $dettaglioLinee, // [] DettaglioLinee
    $datiRiepilogo // [] DatiRiepilogo
);
```

### Esempio completo

[](#esempio-completo)

Di seguito un semplice esempio di utilizzo:

```
$fattura = new FatturaElettronica();

$datiTrasmissione = [
    '12345678910',
    '123'
];

$anagraficaPrestatore = [
    '12345678910',
    'Fornitore srl'
];

$sedePrestatore = [
    'Via Verdi',
    '00100',
    'Roma',
    'RM'
];

$anagraficaCommittente = [
    '12345678911',
    'Cliente srl'
];

$sedeCommittente = [
    'Via Puccini',
    '20100',
    'Milano',
    'MI'
];

$datiGeneraliDocumento = [
    '123',
    '2021-01-01',
    '345.22'
];

$datiGenerali = [$datiGeneraliDocumento];

$dettaglioPagamento = ['345.22'];

$datiDatiPagamento = [$dettaglioPagamento];

$dettaglioLinee = [
    ['Articolo di riga 1', '100.50'],
    ['Articolo di riga 2', '100.50'],
    ['Articolo di riga 3', '100.00', '1', 'pz', '0.00', 'N2.1'],
];

$datiRiepilogo = [
    ['201.00', '22.00'],
    ['100.00', '0.00', 'N2.1'],
];

$datiXml = $fattura->compose(
    $datiTrasmissione,
    $anagraficaPrestatore,
    $sedePrestatore,
    $anagraficaCommittente,
    $sedeCommittente,
    $datiGenerali,
    $datiDatiPagamento,
    $dettaglioLinee,
    $datiRiepilogo
);

var_dump($datiXml);
```

Note
----

[](#note)

Per supporto o bug utilizzare le Issue di Github, per collaborare invece è sufficente aprire un PR con le specifiche dell'integrazione eseguita.

Credits
-------

[](#credits)

Questo pacchetto è stato creato ed è mantenuto da Axio Studio, per maggiori informazioni: .

###  Health Score

30

—

LowBetter than 64% of packages

Maintenance20

Infrequent updates — may be unmaintained

Popularity14

Limited adoption so far

Community10

Small or concentrated contributor base

Maturity64

Established project with proven stability

 Bus Factor1

Top contributor holds 100% of commits — single point of failure

How is this calculated?**Maintenance (25%)** — Last commit recency, latest release date, and issue-to-star ratio. Uses a 2-year decay window.

**Popularity (30%)** — Total and monthly downloads, GitHub stars, and forks. Logarithmic scaling prevents top-heavy scores.

**Community (15%)** — Contributors, dependents, forks, watchers, and maintainers. Measures real ecosystem engagement.

**Maturity (30%)** — Project age, version count, PHP version support, and release stability.

###  Release Activity

Cadence

Every ~10 days

Recently: every ~2 days

Total

9

Last Release

831d ago

Major Versions

0.1 → 1.02024-01-24

PHP version history (2 changes)0.1PHP ^8.1|^8.2

1.0PHP ^8.1|^8.2|^8.3

### Community

Maintainers

![](https://www.gravatar.com/avatar/a78c0f3e62e53947516df18b444bcf2c04cfb6148fd5a94d20707ad118d35e6f?d=identicon)[andrearufo](/maintainers/andrearufo)

![](https://www.gravatar.com/avatar/ccbc7fb7393d0d0d2c78ecde179dbe07bf37f00cf37c5249b2b1b7b0c172138a?d=identicon)[axiostudio](/maintainers/axiostudio)

---

Top Contributors

[![andrearufo](https://avatars.githubusercontent.com/u/2174510?v=4)](https://github.com/andrearufo "andrearufo (1 commits)")

---

Tags

amministrazionefatturafattura-elettronicafattura-painvoiceitaliaitalianpackagephpxmlphplaravelxmlpackagebackendfattura elettronicafatturaitaliapaaxiostudio

###  Code Quality

TestsPHPUnit

Code StylePHP CS Fixer

### Embed Badge

![Health badge](/badges/axiostudio-fattura-elettronica/health.svg)

```
[![Health](https://phpackages.com/badges/axiostudio-fattura-elettronica/health.svg)](https://phpackages.com/packages/axiostudio-fattura-elettronica)
```

###  Alternatives

[rumenx/php-sitemap

Framework-agnostic Sitemap generator for PHP, Laravel, and Symfony.

1.3k15.1k1](/packages/rumenx-php-sitemap)

PHPackages © 2026

[Directory](/)[Categories](/categories)[Trending](/trending)[Changelog](/changelog)[Analyze](/analyze)
