当前位置:首页 > 安全工具 > 正文内容

如何检测智能合约是否使用了代理模式?


你向一个合约发起调用,但真正执行代码的可能不是它本身,而是背后的逻辑合约。这就是代理模式。

代理合约本质上是个"壳"——不实现具体业务逻辑,把收到的所有调用通过delegatecall转发给另一个合约执行。被转发的那个叫逻辑合约或实现合约。

为什么搞这么复杂?核心原因就一个:可升级性。合约部署到链上代码就改不了了,但把业务逻辑放在逻辑合约里,代理合约作为固定入口,只需把代理指向新的逻辑合约就能完成升级。地址不变、余额不变、存储状态不变。USDC、UNI、AAVE这些主流DeFi协议,底层全是代理模式。

各大交易所注册链接:

欧易官网

币安官网

芝麻Gate


代理合约架构示意


方法一:读EIP-1967标准存储槽

EIP-1967规定了一套存储槽,不用翻源代码,直接读特定位置的存储值就能找到逻辑合约地址。

两种查看方式:用eth_getStorageAt接口(开发用),或在区块浏览器合约页面点"Read Contract"。以USDC合约(0xA0b869...)为例,Etherscan上点"Contract"标签,如果看到"Read as Proxy"按钮,说明是EIP-1967标准代理,点进去就能看到实现合约地址。

代理模式逻辑合约存储位置检测方式
EIP-1967透明代理0x360894...bbc直接读该存储槽
EIP-1967信标代理0xa3f0ad...d50读信标地址再查实现
EIP-1822(UUPS)同EIP-1967槽升级逻辑在实现合约中
EIP-897委派代理无固定槽delegateProxyImplementation()
EIP-1167最小代理无存储槽字节码分析:0x363d3d37...
EIP-2535钻石代理多Facet分布多槽特殊检测逻辑

方法二:区块浏览器,最快最直观

不想折腾代码就用浏览器,但不是所有浏览器都支持自动检测。

Etherscan/BscScan上操作:进合约地址页→切到"Contract"标签→看右侧有没有"Read as Proxy"和"Write as Proxy"按钮。有,就是EIP-1967标准代理,点"Read as Proxy"直接看实现合约地址。

注意:没这两个按钮不代表一定不是代理。未遵循EIP-1967的自定义代理、新部署未被索引的、某些EIP-1167最小克隆代理,都不会显示。


方法三:翻源码找delegatecall

代理模式的代码特征非常明显,打开源代码找三个关键点:

特征1delegatecall出现在fallback函数里。真正的代理合约几乎一定包含这条EVM指令,在assembly { ... }代码块里搜delegatecall,搜到基本确认。OpenZeppelin代理模板里_delegate()函数的核心就是它。

特征2:有_implementation()函数返回某个地址。这个函数指向的如果不是零地址,就是在告诉你真正的代码在哪。

特征3fallback()没有任何具体业务逻辑。标准业务合约的fallback通常很短或不写,代理合约却用它接收所有调用并转发。代码高度标准化,一眼能认出来。


三种方法对比

方法难度准确性适用场景
浏览器"Read as Proxy"★☆☆☆☆取决于是否遵循EIP-1967日常快速查看
读EIP-1967存储槽★★☆☆☆高(遵循标准时)确认标准化代理
手动翻源码找delegatecall★★★★☆最高验证非标准代理、安全审计
evm-proxy-detection工具★★☆☆☆批量检测、开发场景
EVMProxyInspect★★★☆☆多链批量检测,支持12种代理

三种检测方法对比


三步确认一个合约是不是代理

  1. 浏览器看一眼→Contract标签有没有"Read as Proxy"?有,确认代理,复制逻辑合约地址。没有,下一步。

  2. 翻代码搜"delegatecall"→找到,大概率是代理,再找_implementation()看指向哪。找不到但怀疑是代理,下一步。

  3. 上工具→单查用evm-proxy-detection,批量多链用EVMProxyInspect,深度安全分析用EVM Proxy MCP。


声明:本文为代理模式检测科普,不构成操作建议。各合约实现有差异,以链上数据和官方文档为准。


相关文章

检测合约能不能增发:2026年防砸盘工具箱

检测合约能不能增发:2026年防砸盘工具箱

2026年3月,Solana迷因币VELOXY从零点几美元冲到14美元。持有者还没来得及高兴,链上数据揭示了真相:项目方直接铸造了几百万个新币,所有人的份额被无声稀释殆尽。这种事每天都在发生。项目方赚...

检测代币是否有貔貅机制

检测代币是否有貔貅机制

去年一个朋友在群里兴奋地说他买到了一个"早期金狗",说这个币池子小、持有人少、合约刚部署几个小时,买进去之后价格一直在涨。他想加仓问我有没有兴趣。我说你先别加,把你买的那个代币合约...

检测合约增发权限的网站与工具

检测合约增发权限的网站与工具

半夜被一条消息震醒,小币社群炸了,说项目方刚刚增发了五千万枚币,价格直接腰斩。翻出合约地址扔进区块浏览器,点开Read Contract那一栏,赫然躺着一个mint函数,owner地址正是项目方钱包。...

检测代币隐藏买卖税的方法

检测代币隐藏买卖税的方法

一个代币看起来走势不错,流动性也厚实,你买入100 U试试水——交易成功,钱包多了10万个代币。准备用同样的金额卖掉获利,结果卖完10万个代币,回到钱包只有70多U。没买错,没被抢跑,全因为合约里锁了...

检测合约所有权是否已放弃的工具

检测合约所有权是否已放弃的工具

在ERC-20代币标准里,部署合约的地址会自动获得一个特权账户——所有者(Owner),它能修改代币税费、暂停交易、甚至增发代币。2026年GoPlus Security披露过一个案例:Ronaldi...

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。