层级化NFT标准诞生:EIP-6150
前言
因为一些机缘,我最近和几个同行朋友一起提交了一个新的 EIP 协议标准,EIP-6150,这是一个支持层级结构的 NFT 协议标准,撰写此文时处在 Review 状态,改为 Last Call 状态的 PR 还在等待通过。
该协议标准有 4 位作者:Keegan Lee、msfew、Kartin 和 qizhou。Keegan Lee 就是我,主要负责了接口的定义和实现代码的编写。Kartin 是这个 EIP 的发起人,也是 Hyper Oracle 的创始人。msfew 则是 Hyper Oracle 的研究员,主要帮忙做一些辅助性的工作,包括完善文档、提交 PR、跟进讨论区的 QA 等。qizhou 是 EthStorage 的创始人,之前就提交过其他 EIP,熟悉申请 EIP 的流程,也对以太坊基金会的人比较熟悉,为这个协议提供了很多指导。以下是该 EIP-6150 的 github 地址:
https://github.com/ethereum/EIPs/blob/master/EIPS/eip-6150.md
Hierarchical NFTs
目前的 NFT 几乎都是扁平化的,不同 NFT 之间不存在关联关系。而层级化的 NFT,则可以将所有 NFT 串联起来组成树状结构,就像文件系统一样。

如上图所示,可以想象成每个文件夹都是一个单独的 NFT,不同文件夹之间的层级关系也就是 NFT 之间的层级关系。
层级化的 NFT 可用于多种不同的应用场景,比如:
- 组织架构
- 社交关系图谱
- 电商商品类目结构
- 层级评论系统
可以说,任何具有层级结构的场景都可以适用这个 EIP-6150 协议标准。层级结构的 NFT 在去中心化社交、去中心化电商等领域都将可能产生广泛应用。
接口定义
EIP-6150 总共定义了 5 个接口文件:
- IERC6150
- IERC6150Enumerable
- IERC6150Burnable
- IERC6150ParentTransferable
- IERC6150AccessControl
IERC6150
IERC6150是规定必须实现的接口,最小化定义了一个事件和四个函数,且要求继承 IERC165 和 IERC721 接口,接口定义如下:

Minted事件需在铸造一个新的 NFT 时发出,记录了新 NFT 的铸造者(minter)、接收者(to)、父节点 NFT 的 ID(parentId)、新 NFT ID(tokenId)。当铸造一个根节点 NFT 时,那 parentId 则记为 0,即 0 表示一个无效的空节点,因此,有效的节点 NFT 的 tokenId 就不可以为 0。
parentOf函数用于查询指定 tokenId 的 NFT 的父节点 NFT。
childrenOf函数则查询出指定 tokenId 的 NFT 的所有子节点 NFTs。
isRoot和isLeaf函数则分别可查询指定 tokenId 在整个 NFT 层级树中是不是根节点或叶子节点。
IERC6150Enumerable
IERC6150Enumerable是可选的扩展接口,主要补充了几个跟层级相关的 Enumerable 的查询接口,接口定义如下:

继承IERC721Enumerable也是可选的,但为了更好地兼容 ERC721,最好可以继承。childrenCountOf函数用于查询指定节点下有多少个子节点,如果参数 parentId 为 0,则表示查询根节点的数量。childOfParentByIndex函数则是从指定的父节点下的所有子节点数组中找出指定索引位置的子节点的 tokenId,比如指定父节点 parentId = 110,其下有 10 个子节点,找出索引位置为 5 的子节点 tokenId = 1105,则查询结果返回 1105。indexInChildrenEnumeration函数则是查询指定的 tokenId 在指定父节点下的子节点数组中所在的索引位置,比如指定 tokenId = 1105,父节点 parentId = 110,1105 在子节点数组中的索引位置为 5,则查询结果返回 5。如果指定 tokenId 并不在指定父节点 parentId 下面,则需要抛出错误。
IERC6150Burnable
IERC6150Burnable也是可选的扩展接口,定义了销毁节点的操作,接口定义如下:

只定义了两个函数,safeBurn用于安全销毁单个节点,但要求只有指定节点为叶子节点时才允许销毁。就和 Linux 的文件系统一样,如果某目录下存在其他文件或文件夹,是不允许直接删除的。若强制删除,则目录下的所有文件和文件夹都会被级联式全部删除。当前协议没有定义级联式删除的函数,若有这个需求,可以自己再额外去添加函数实现。safeBatchBrun函数则是用于批量销毁多个叶子节点。
IERC6150ParentTransferable
IERC6150ParentTransferable也是一个可选的扩展接口,支持层级关系的转移,就和文件夹可以从一个目录移动到另一个目录一样,接口定义如下:

接口定义了两个函数和一个事件,支持单节点的转移,也支持多节点的批量转移。每个节点发生层级关系转移时,需要抛出ParentTransferred事件,记录下所转移的 tokenId、旧的父节点 ID 和新的父节点 ID。transferParent将指定的 tokenId 转移到指定的父节点下,若指定的父节点为 0,则表示指定节点改为了根节点。batchTransferParent则可以指定多个 tokenId,批量将这些节点都转移到指定的父节点下。
IERC6150AccessControl
最后一个接口IERC6150AccessControl也是可选的,提供了几个权限控制的函数,接口定义如下:

总共定义了三个函数,isAdminOf用于查询指定的 account 对指定的 tokenId 是否有管理员权限。在 ERC721 中,每个 NFT 都只有唯一的 owner 并拥有管理权限。但在层级式的结构中,一个 NFT 是可以有多个管理员的,就和文件系统中可以有多个管理员一样。这个扩展接口就提供了支持多管理员的模式,但对于怎么设置多个管理员,则难以定义通用函数,所以就没做标准化的定义。不过,需要保证,NFT 的 owner 同时也是管理员。
canMintChildren则用来判定某个 account 对指定的 parentId 是否具有铸造子节点的权限。
canBurnTokenByAccount则用来检查某个 account 对指定的 tokenId 是否具有销毁的权限。
参考实现
EIP 的 github 上,我对每个接口都提供了对应的参考实现代码,代码地址如下:
https://github.com/ethereum/EIPs/tree/master/assets/eip-6150/contracts
但这里我不打算对每个实现代码都一一讲解,我只讲最核心的ERC6150.sol的实现。因为代码相对有点长,就不贴代码出来了,大家可以点击链接进去看代码。我主要讲讲实现的一些逻辑和思路。
存储上,用了三个 mapping:_parentOf、_childrenOf、_indexInChildrenArray,分别用来存储指定节点的:父节点、子节点数组、所在子节点数组里的索引位置。有了这三个 mapping 之后,几个查询函数的实现就非常简单了,我就不细说了。核心是_safeMintWithParent和_safeBurn函数,分别是铸造 NFT 和销毁 NFT 的内部函数。
铸造函数的代码如下:

实现逻辑其实也很简单,有两个校验需要注意下,一是要铸造的新 NFT 的 tokenId 需要大于 0,正如前面所说的,0 为无效节点;二是当 parentId 不为 0 时,需保证 parentId 是存在的,当 parentId 为 0 时,则表示铸造的是根节点 NFT。_beforeMintWithParent和_afterMintWithParent是为了增加扩展性而增加的,可由继承此合约的上层合约根据需求再去实现。中间代码就是对几个 mapping 进行赋值了,然后调用了 ERC721 的_safeMint函数实现底层的铸造,接着就发送 Minted 事件了。
这个铸造函数是 internal virtual 的,上层合约可以重载该函数,且上层的实现合约需要再根据具体需求自己添加开放的铸造函数。
接着看看销毁函数,代码如下:

销毁时,要求 tokenId 是存在的且需是叶子节点才允许销毁。另外,销毁时,需要从子节点数组中移除,而为了节省 gas,同时把子节点数组中的最后一个元素移到了销毁的索引位置。
另外,实现代码中,也封装了批量铸造的内部函数,方便扩展支持批量铸造多个子节点的需求。
其实,整个协议并不复杂,但已经足以覆盖到很多应用场景,后续我会结合一些具体的应用场景,再增加示例代码作为案例,以促进该协议的落地应用。
1.资讯内容不构成投资建议,投资者应独立决策并自行承担风险
2.本文版权归属原作所有,仅代表作者本人观点,不代表本站的观点或立场
您可能感兴趣
-
DEX 没凉,CEX 只是借东风作者:Prathik Desai 编译:Block unicorn前言 对于中心化交易所 (CEX) 和去中心化交易所 (DEX) 而言,过去一年都是充满变数的一年。在过去的 12 到 18 个月里,
-
Gate 研究院:资本化的加密信仰,加密财库模式可持续性探讨作者:Gate 研究院摘要 • Strategy 开创了加密资产储备财库的先河,更多上市公司追随 Strategy 的脚步转型并开启了 DAT 新篇章。2025 年 DAT 规模出现爆发式增长,以太坊
-
Galaxy Digital:从波动到可预测作者:Prathik Desai 编译:Block unicorn推土机在酷热中闲置。地段荒凉,合同不确定,一个加密货币交易公司转型为电力公司的想法似乎是痴人说梦。 一年前,德克萨斯州的 Helios
-
大仙说币:10.29 美联储降息板上钉钉,比特币意外跌破 113000 关口随着美国CPI年增率将至3.0%,强化了市场对联准会即将降息的预期;同时,Zhong美预计在周四早上九点在首尔举行高峰会,缓解全球地缘zz紧张。美股受此影响三大指数于28日收盘再创新高,但比特币形成高
-
火币成长学院 | x402 深度研报:互联网支付范式的重构与投资启示一、项目背景及概述 自20世纪90年代互联网兴起以来,HTTP协议一直是信息传输的基石。它定义了浏览器与服务器之间如何沟通,也塑造了互联网的使用习惯。然而,在HTTP/1.1标准中,有一个长期被忽视的
-
大仙说币:10.30 凌晨降息如期而至,鲍威尔放话 12 月降息未成定局,比特币应声下跌美国联准会在今日凌晨两点传来关键决策,主席鲍威尔宣布降息一码,使联邦资金利率区间将至3.75%-4%,并宣布12月1日起停止缩减资产负债表,也就是暂停量化紧缩。尽管这两项决策带有明显的宽松色彩,但在随
-
如何参与 Stable 第二轮预存款活动作者:CoinW 研究院稳定币是连接传统金融与加密世界的桥梁,在 DeFi 借贷、交易市场和跨境支付中发挥重要作用。随着市场成熟和监管演变,稳定币正从“单一资产”发展为底层网络。新兴稳定币公链以稳定币
-
HashWhale 加密周报 | 利好兑现后资金回吐;市场短期面临震荡(10.25-10.31)作者&编辑:蒙奇1、比特币市场比特币价格走势(2025/10/25-2025/10/31) 横盘整理阶段(10月25日至10月26日) 10月25日,比特币价格自 $110,000 逐步小幅攀升至 $
- 成交量排行
- 币种热搜榜
OFFICIAL TRUMP
Pepe
泰达币
以太坊
比特币
Solana
USD Coin
币安币
瑞波币
First Digital USD
狗狗币
大零币
莱特币
Sui
ChainLink
OKB
FIL
DYDX
ZEN
CAKE
HBAR
CFX
EOS
BSV