Standard Multi-Token ERC-1155
Ultimo aggiornamento della pagina: 22 ottobre 2025
Introduzione
Un'interfaccia standard per i contratti che gestiscono più tipi di token. Un singolo contratto distribuito può includere qualsiasi combinazione di token fungibili, token non fungibili o altre configurazioni (ad es., token semi-fungibili).
Cosa si intende per Standard Multi-Token?
L'idea è semplice e cerca di creare un'interfaccia per contratti intelligenti in grado di rappresentare e controllare un numero qualsiasi di tipi di token fungibili e non fungibili. In questo modo, il token ERC-1155 può svolgere le stesse funzioni di un token ERC-20 e ERC-721, e persino di entrambi contemporaneamente. Migliora la funzionalità di entrambi gli standard ERC-20 ed ERC-721, rendendolo più efficiente e correggendo evidenti errori di implementazione.
Il token ERC-1155 è descritto completamente nell'EIP-1155 (opens in a new tab).
Prerequisiti
Per comprendere meglio questa pagina, ti consigliamo di leggere prima gli standard dei token, l'ERC-20 e l'ERC-721.
Funzioni e caratteristiche dell'ERC-1155:
- Trasferimento in blocco: Trasferisce più asset in una singola chiamata.
- Saldo in blocco: Ottiene i saldi di più asset in una singola chiamata.
- Approvazione in blocco: Approva tutti i token per un indirizzo.
- Hook: Hook per la ricezione dei token.
- Supporto NFT: Se la fornitura è solo 1, lo tratta come NFT.
- Regole di trasferimento sicuro: Insieme di regole per un trasferimento sicuro.
Trasferimenti in blocco
Il trasferimento in blocco funziona in modo molto simile ai normali trasferimenti ERC-20. Diamo un'occhiata alla normale funzione transferFrom dell'ERC-20:
1// ERC-202function transferFrom(address from, address to, uint256 value) external returns (bool);34// ERC-11555function safeBatchTransferFrom(6 address _from,7 address _to,8 uint256[] calldata _ids,9 uint256[] calldata _values,10 bytes calldata _data11) external;Mostra tuttoL'unica differenza nell'ERC-1155 è che passiamo i valori come un array e passiamo anche un array di ID. Ad esempio, dati ids=[3, 6, 13] e values=[100, 200, 5], i trasferimenti risultanti saranno:
- Trasferimento di 100 token con ID 3 da
_froma_to. - Trasferimento di 200 token con ID 6 da
_froma_to. - Trasferimento di 5 token con ID 13 da
_froma_to.
Nell'ERC-1155 abbiamo solo transferFrom, non transfer. Per usarlo come un normale transfer, basta impostare l'indirizzo di provenienza (from) all'indirizzo che sta chiamando la funzione.
Saldo in blocco
La rispettiva chiamata balanceOf dell'ERC-20 ha analogamente la sua funzione partner con supporto per i blocchi. Come promemoria, questa è la versione ERC-20:
1// ERC-202function balanceOf(address owner) external view returns (uint256);34// ERC-11555function balanceOfBatch(6 address[] calldata _owners,7 uint256[] calldata _ids8) external view returns (uint256[] memory);Ancora più semplice per la chiamata del saldo, possiamo recuperare più saldi in una singola chiamata. Passiamo l'array dei proprietari, seguito dall'array degli ID dei token.
Ad esempio, dati _ids=[3, 6, 13] e _owners=[0xbeef..., 0x1337..., 0x1111...], il valore restituito sarà:
1[2 balanceOf(0xbeef...),3 balanceOf(0x1337...),4 balanceOf(0x1111...)5]Approvazione in blocco
1// ERC-11552function setApprovalForAll(3 address _operator,4 bool _approved5) external;67function isApprovedForAll(8 address _owner,9 address _operator10) external view returns (bool);Mostra tuttoLe approvazioni sono leggermente diverse rispetto all'ERC-20. Invece di approvare importi specifici, si imposta un operatore come approvato o non approvato tramite setApprovalForAll.
La lettura dello stato attuale può essere effettuata tramite isApprovedForAll. Come puoi vedere, è un'operazione del tipo tutto o niente. Non puoi definire quanti token approvare o persino quale classe di token.
Questo è stato progettato intenzionalmente tenendo a mente la semplicità. Puoi solo approvare tutto per un indirizzo.
Hook di ricezione
1function onERC1155BatchReceived(2 address _operator,3 address _from,4 uint256[] calldata _ids,5 uint256[] calldata _values,6 bytes calldata _data7) external returns(bytes4);Dato il supporto dell'EIP-165 (opens in a new tab), l'ERC-1155 supporta gli hook di ricezione solo per i contratti intelligenti. La funzione hook deve restituire un valore magico predefinito bytes4 che è dato come:
1bytes4(keccak256("onERC1155BatchReceived(address,address,uint256[],uint256[],bytes)"))Quando il contratto ricevente restituisce questo valore, si presume che il contratto accetti il trasferimento e sappia come gestire i token ERC-1155. Ottimo, niente più token bloccati in un contratto!
Supporto NFT
Quando la fornitura è solo una, il token è essenzialmente un token non fungibile (NFT). E come è standard per l'ERC-721, puoi definire un URL di metadati. L'URL può essere letto e modificato dai client, vedi qui (opens in a new tab).
Regola di trasferimento sicuro
Abbiamo già accennato ad alcune regole di trasferimento sicuro nelle spiegazioni precedenti. Ma diamo un'occhiata alla più importante delle regole:
- Il chiamante deve essere approvato per spendere i token per l'indirizzo
_fromo il chiamante deve essere uguale a_from. - La chiamata di trasferimento deve essere annullata (revert) se:
- L'indirizzo
_toè 0. - La lunghezza di
_idsnon è uguale alla lunghezza di_values. - Qualsiasi saldo dei titolari per i token in
_idsè inferiore ai rispettivi importi in_valuesinviati al destinatario. - Si verifica qualsiasi altro errore.
- L'indirizzo
Nota: Tutte le funzioni in blocco (batch), incluso l'hook, esistono anche in versioni senza blocco. Questo viene fatto per l'efficienza del gas, considerando che il trasferimento di un solo asset sarà probabilmente ancora il modo più comunemente usato. Le abbiamo omesse per semplicità nelle spiegazioni, incluse le regole di trasferimento sicuro. I nomi sono identici, basta rimuovere 'Batch'.