ERC777是一个新的高级代币标准,可以视为ERC20的升级版本,因此它解决了ERC20以及ERC223存在的一些问题,开发者可以根据自己的具体需求进行选型。
1、使用ERC820进行合约注册
有别于ERC20的自由散漫,ERC777利用了新的ERC820标准提供的集中式的智能合约注册表和合约接口实现查询功能,以实现某种程度的内省。中心化的注册机制有助于后向兼容性以及更好的功能扩展。一个期望调用ERC777的DApp或智能合约,就可以利用EIP-820返回的ITokenReceipt接口来确定目标合约是否实现了期望的接口。
2、ERC777概述
ERC777改进了ERC20代币中存在的很多不足,例如,ERC777支持操作员白名单,提供以太币兼容的send()接口,利用ERC20实现后向兼容等。下图展示了ERC777代币的转账实现流程:
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-l1uEb5mi-1571697124280)(erc-777-anatomy/transfer.png)]](https://img-blog.csdnimg.cn/20191022063315869.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3NoZWJhbzMzMzM=,size_16,color_FFFFFF,t_70)
要快速掌握以太坊区块链应用开发,推荐汇智网的在线互动教程:
以太坊DApp开发入门 | 以太坊电商DApp实战 | ERC721以太坊通证实战
Web3j以太坊开发详解 | Php以太坊开发详解 | Python以太坊开发详解 | C#以太坊开发详解 | Flutter以太坊开发详解 |
与ERC20相比,ERC777有以下方面的优势:
- 采用与以太币一致的哲学发送代币,即采用接口
send(dest,value,data)。 - 任何合约都可以定义收到代币时触发的
tokensReceived事件,这避免了在ERC20代币
中存在的双重调用问题。 - 合约和常规地址都可以通过注册一个
tokensToSend或tokensReceivedFunction
函数来控制或拒绝发送或接收的代币,避免ERC20代币中存在的代币卡死问题。 - 代币持有者可以授权或回收管理其代币的操作员权限。这些操作员通常是交易所
合约或自动收费系统中的支付处理器。 - 每个代币交易都包含
userData数据字段,在操作员操作时也有类似的operatorData
字段,从而可以自由地将数据传递给接收方。 - 可以后向兼容那些不支持
tokensReceived函数的钱包。
3、ERC777规范
下面是ERC777规范的内容,完整描述可以到官网查看:
interface ERC777Token { function name() external view returns (string memory); function symbol() external view returns (string memory); function totalSupply() external view returns (uint256); function balanceOf(address holder) external view returns (uint256); function granularity() external view returns (uint256); function defaultOperators() external view returns (address[] memory); function isOperatorFor( address operator, address holder ) external view returns (bool); function authorizeOperator(address operator) external; function revokeOperator(address operator) external; function send(address to, uint256 amount, bytes calldata data) external; function operatorSend( address from, address to, uint256 amount, bytes calldata data, bytes calldata operatorData ) external; function burn(uint256 amount, bytes calldata data) external; function operatorBurn( address from, uint256 amount, bytes calldata data, bytes calldata operatorData ) external; event Sent( address indexed operator, address indexed from, address indexed to, uint256 amount, bytes data, bytes operatorData ); event Minted( address indexed operator, address indexed to, uint256 amount, bytes data, bytes operatorData ); event Burned( address indexed operator, address indexed from, uint256 amount, bytes data, bytes operatorData ); event AuthorizedOperator( address indexed operator, address indexed holder ); event RevokedOperator(address indexed operator, address indexed holder);}ERC777代币合约必须通过ERC820标准注册ERC777Token接口。基准单位必须是10¹⁸。
Logo

ERC777代币logo采用Creative Commons Attribution-ShareAlike 4.0授权,并且不可以用于广告、推广或其他任何不兼容ERC777的技术。
后向兼容性
ERC777没有引入后向不兼容问题,因此可以兼容之前的ERC20代币标准。
在这个RIP中,没有使用transfer和transferFrom进行代币转账,而是使用send和operatorSend来避免混淆与潜在的错误。与此同时,ERC777允许你实现ERC20中的transfer、transferFrom、approve和allowance以便兼容ERC20。
因此一个代币合约可以同时实现ERC20和ERC777。只读函数例如name、symbol、balanceOf、tokenSupply以及内部数据例如余额映射表等都可以毫无问题的重叠使用。但是需要注意的是,以下函数是ERC777规范强制要求的:name 、 symbol,不过decimal并非ERC777标准中的要求。
两个标准中的写操作函数都是解耦的,可以彼此独立的操作。注意ERC20函数应当仅限于既有合约的调用。
如果代币合约实现了ERC20,那么它必须通过ERC820注册ERC20Token接口。如果合约支持切换启用或禁止ERC20的方法,那么每次进行切换时,该代币合约必须通过ERC820注册或解除RC20Token接口的注册。
对于实现ERC20的新合约而言,唯一的区别在于ERC777TokensSender和ERC777TokensRecipient通过ERC820的注册必须早于ERC20的注册。这意味着即使是对ERC20的transfer方法的调用,代币合约也必须通过ERC820检查from或to是否实现了tokensToSend/tokensReceived接口并在可用时进行调用。注意当调用合约的ERC20的transfer方法时,如果合约没有实现tokensReceived接口,那么transfer也应当被接受,这意味着代币可能会被锁定。
继续阅读与本文标签相同的文章
Spring Boot 快速入门
重学计算机组成原理(十二) - 异常和中断
-
企业上云要注意哪些事项?
2026-05-17栏目: 教程
-
企业上云有什么好处?
2026-05-17栏目: 教程
-
阿里云网站备案申请被驳回的问题解答汇总
2026-05-17栏目: 教程
-
Install Tensorflow 2.0 in Conda on Windows 10
2026-05-17栏目: 教程
-
linux 软raid实现,lvm管理
2026-05-17栏目: 教程
