ERC-1155 బహుళ-టోకెన్ ప్రమాణం
పేజీ చివరి అప్డేట్: 14 ఫిబ్రవరి, 2026
పరిచయం
బహుళ టోకెన్ రకాలను నిర్వహించే కాంట్రాక్టుల కోసం ఒక ప్రామాణిక ఇంటర్ఫేస్. ఒకే డిప్లాయ్ చేసిన కాంట్రాక్టులో ఫంగిబుల్ టోకెన్లు, నాన్-ఫంగిబుల్ టోకెన్లు లేదా ఇతర కాన్ఫిగరేషన్ల (ఉదా., సెమీ-ఫంగిబుల్ టోకెన్లు) కలయిక ఏదైనా ఉండవచ్చు.
బహుళ-టోకెన్ ప్రమాణం అంటే ఏమిటి?
ఈ ఆలోచన సరళమైనది మరియు ఫంగిబుల్ మరియు నాన్-ఫంగిబుల్ టోకెన్ రకాల యొక్క ఏ సంఖ్యనైనా ప్రాతినిధ్యం వహించగల మరియు నియంత్రించగల స్మార్ట్ కాంట్రాక్ట్ ఇంటర్ఫేస్ను రూపొందించడానికి ప్రయత్నిస్తుంది. ఈ విధంగా, ERC-1155 టోకెన్ ERC-20 మరియు ERC-721 టోకెన్ వలె అదే విధులను చేయగలదు మరియు ఒకే సమయంలో రెండింటినీ కూడా చేయగలదు. ఇది ERC-20 మరియు ERC-721 ప్రమాణాల రెండింటి కార్యాచరణను మెరుగుపరుస్తుంది, దానిని మరింత సమర్థవంతంగా చేస్తుంది మరియు స్పష్టమైన ఇంప్లిమెంటేషన్ లోపాలను సరిచేస్తుంది.
ERC-1155 టోకెన్ EIP-1155opens in a new tabలో పూర్తిగా వివరించబడింది.
అవసరాలు
ఈ పేజీని మరింత బాగా అర్థం చేసుకోవడానికి, మీరు ముందుగా టోకెన్ ప్రమాణాలు, ERC-20, మరియు ERC-721 గురించి చదవాలని మేము సిఫార్సు చేస్తున్నాము.
ERC-1155 ఫంక్షన్లు మరియు ఫీచర్లు:
- బ్యాచ్ బదిలీ: ఒకే కాల్లో బహుళ ఆస్తులను బదిలీ చేయండి.
- బ్యాచ్ బ్యాలెన్స్: ఒకే కాల్లో బహుళ ఆస్తుల బ్యాలెన్స్లను పొందండి.
- బ్యాచ్ ఆమోదం: ఒక చిరునామాకు అన్ని టోకెన్లను ఆమోదించండి.
- హుక్స్: టోకెన్లను స్వీకరించే హుక్.
- NFT మద్దతు: సరఫరా 1 మాత్రమే అయితే, దాన్ని NFTగా పరిగణించండి.
- సురక్షిత బదిలీ నియమాలు: సురక్షిత బదిలీ కోసం నియమాల సమితి.
బ్యాచ్ బదిలీలు
బ్యాచ్ బదిలీ సాధారణ ERC-20 బదిలీల మాదిరిగానే పనిచేస్తుంది. సాధారణ ERC-20 transferFrom ఫంక్షన్ను చూద్దాం:
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;అన్నీ చూపించుERC-1155లో ఉన్న ఏకైక తేడా ఏమిటంటే, మేము విలువలను శ్రేణిగా పంపుతాము మరియు మేము ఐడిల శ్రేణిని కూడా పంపుతాము. ఉదాహరణకు, ids=[3, 6, 13] మరియు values=[100, 200, 5] అని ఇచ్చినప్పుడు, ఫలితంగా వచ్చే బదిలీలు ఇలా ఉంటాయి
_fromనుండి_toకు ఐడి 3 తో 100 టోకెన్ల బదిలీ._fromనుండి_toకు ఐడి 6 తో 200 టోకెన్ల బదిలీ._fromనుండి_toకు ఐడి 13 తో 5 టోకెన్ల బదిలీ.
ERC-1155లో మనకు transferFrom మాత్రమే ఉంది, transfer లేదు. దీనిని ఒక సాధారణ transfer లాగా ఉపయోగించడానికి, కేవలం ఫంక్షన్ను పిలుస్తున్న చిరునామాకు from చిరునామాను సెట్ చేయండి.
బ్యాచ్ బ్యాలెన్స్
సంబంధిత ERC-20 balanceOf కాల్ కూడా బ్యాచ్ మద్దతుతో దాని భాగస్వామి ఫంక్షన్ను కలిగి ఉంది. జ్ఞాపికగా, ఇది 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);బ్యాలెన్స్ కాల్ కోసం ఇంకా సరళంగా, మనం ఒకే కాల్లో బహుళ బ్యాలెన్స్లను పొందవచ్చు. మేము యజమానుల శ్రేణిని, దాని తర్వాత టోకెన్ ఐడిల శ్రేణిని పంపుతాము.
ఉదాహరణకు _ids=[3, 6, 13] మరియు _owners=[0xbeef..., 0x1337..., 0x1111...] అని ఇచ్చినప్పుడు, తిరిగి వచ్చే విలువ ఇలా ఉంటుంది
1[2 balanceOf(0xbeef...),3 balanceOf(0x1337...),4 balanceOf(0x1111...)5]బ్యాచ్ ఆమోదం
1// ERC-11552function setApprovalForAll(3 address _operator,4 bool _approved5) external;67function isApprovedForAll(8 address _owner,9 address _operator10) external view returns (bool);అన్నీ చూపించుఆమోదాలు ERC-20 కంటే కొద్దిగా భిన్నంగా ఉంటాయి. నిర్దిష్ట మొత్తాలను ఆమోదించడానికి బదులుగా, మీరు setApprovalForAll ద్వారా ఒక ఆపరేటర్ను ఆమోదించబడిన లేదా ఆమోదించబడనిదిగా సెట్ చేస్తారు.
ప్రస్తుత స్థితిని isApprovedForAll ద్వారా చదవవచ్చు. మీరు చూడగలిగినట్లుగా, ఇది అన్నీ-లేదా-ఏమీ-లేని ఆపరేషన్. ఎన్ని టోకెన్లను ఆమోదించాలో లేదా ఏ టోకెన్ క్లాస్ను ఆమోదించాలో కూడా మీరు నిర్వచించలేరు.
ఇది ఉద్దేశపూర్వకంగా సరళతను దృష్టిలో ఉంచుకుని రూపొందించబడింది. మీరు ఒక చిరునామా కోసం అన్నింటినీ మాత్రమే ఆమోదించగలరు.
రిసీవ్ హుక్
1function onERC1155BatchReceived(2 address _operator,3 address _from,4 uint256[] calldata _ids,5 uint256[] calldata _values,6 bytes calldata _data7) external returns(bytes4);EIP-165opens in a new tab మద్దతును బట్టి, ERC-1155 స్మార్ట్ కాంట్రాక్ట్ల కోసం మాత్రమే రిసీవ్ హుక్స్కు మద్దతు ఇస్తుంది. హుక్ ఫంక్షన్ తప్పనిసరిగా ఒక మ్యాజిక్ ముందే నిర్వచించిన bytes4 విలువను తిరిగి ఇవ్వాలి, అది ఇలా ఇవ్వబడింది:
1bytes4(keccak256("onERC1155BatchReceived(address,address,uint256[],uint256[],bytes)"))స్వీకరించే కాంట్రాక్టు ఈ విలువను తిరిగి ఇచ్చినప్పుడు, కాంట్రాక్టు బదిలీని అంగీకరిస్తుందని మరియు ERC-1155 టోకెన్లను ఎలా నిర్వహించాలో దానికి తెలుసు అని భావించబడుతుంది. అద్భుతం, ఇకపై కాంట్రాక్ట్లో టోకెన్లు చిక్కుకోవు!
NFT మద్దతు
సరఫరా కేవలం ఒకటి మాత్రమే అయినప్పుడు, ఆ టోకెన్ ముఖ్యంగా ఒక నాన్-ఫంగిబుల్ టోకెన్ (NFT). మరియు ERC-721కి ప్రమాణంగా ఉన్నట్లుగా, మీరు ఒక మెటాడేటా URLని నిర్వచించవచ్చు. URLను ఖాతాదారులు చదవవచ్చు మరియు సవరించవచ్చు, ఇక్కడopens in a new tab చూడండి.
సురక్షిత బదిలీ నియమం
మేము మునుపటి వివరణలలో ఇప్పటికే కొన్ని సురక్షిత బదిలీ నియమాల గురించి ప్రస్తావించాము. అయితే, నియమాలలో అత్యంత ముఖ్యమైన వాటిని చూద్దాం:
_fromచిరునామా కోసం టోకెన్లను ఖర్చు చేయడానికి కాలర్ ఆమోదం పొంది ఉండాలి లేదా కాలర్_fromతో సమానంగా ఉండాలి.- బదిలీ కాల్ తప్పనిసరిగా రివర్ట్ అవ్వాలి, ఒకవేళ:
_toచిరునామా 0 అయితే._idsయొక్క పొడవు_valuesయొక్క పొడవుకు సమానంగా లేకపోతే._idsలోని టోకెన్(ల) కోసం హోల్డర్(ల) యొక్క ఏదైనా బ్యాలెన్స్(లు), గ్రహీతకు పంపబడిన_valuesలోని సంబంధిత మొత్తం(ల) కంటే తక్కువగా ఉంటే.- మరేదైనా లోపం సంభవిస్తే.
గమనిక: హుక్తో సహా అన్ని బ్యాచ్ ఫంక్షన్లు బ్యాచ్ లేని వెర్షన్లుగా కూడా ఉన్నాయి. కేవలం ఒక ఆస్తిని బదిలీ చేయడమే ఇప్పటికీ అత్యంత సాధారణంగా ఉపయోగించబడే మార్గం అని పరిగణనలోకి తీసుకుని, గ్యాస్ సామర్థ్యం కోసం ఇది చేయబడింది. వివరణలలో సరళత కోసం, సురక్షిత బదిలీ నియమాలతో సహా మేము వాటిని వదిలిపెట్టాము. పేర్లు ఒకేలా ఉంటాయి, కేవలం 'బ్యాచ్'ను తొలగించండి.