
必备九条措施 保障智能合约安全性
以太坊开发者需要知道的四项安全性原则,以及一些基本权衡。
尽管区块链行业的发展日趋成熟,但是智能合约的开发仍是一个相对较新的领域。因此,为了应对新的漏洞和安全危机,以及满足开发新的最佳实践的需要,我们应该不断完善安全性方面的问题。学习最佳实践只是智能合约开发者在安全性方面踏出的第一步。
智能合约编程需要一种不同于传统的工程思维。智能合约失败的代价很高,更新迭代需要较大工程量,这使得它在某些方面更类似于硬件编程或金融服务编程,而不是web或者移动端开发。因此,仅仅防御已知的风险是远远不够的,还需要掌握新的开发理念。
准备应急措施
任何重要的合约都会出现故障。因此,开发者必须做好充足的准备,以便及时应对漏洞。
-
出现故障时暂停合约 (“断路器”)。
-
管理风险资金的数量 (限制流量,最大化利用率)。
-
准备有效的升级路径以修复和改进bug。
防患未然
最好是在完整的产品发布之前发现bug。
-
全面测试合约,并在发现新的攻击向量时添加相应测试。
-
alpha测试网版本发布之后,提供bug赏金。
-
分阶段推出,每个阶段更新功能并添加新测试。
保持智能合约的简洁性
复杂性会提高出现故障的概率。
-
确保合约逻辑简单。
-
模块化代码以使合约和函数保持较小。
-
请尽可能使用既有工具或代码 (例如不要使用自己的随机数生成器)。
-
在保证清晰度的前提下再考虑性能。
-
只在系统中需要去中心化的部分使用区块链技术。
保持更新
跟进新的安全性措施。
-
检查智能合约,以最快的速度定位新漏洞。
-
尽快升级到任何工具或库的最新版本。
-
采用可能有效的保障安全性的新技术。
了解EVM的特性
-
尽管开发者对以太坊编程较熟悉,但仍需要注意一些陷阱。
-
要特别小心外部合约调用,该过程可能会执行恶意代码并改变控制流 (control flow)。
-
要明白,开发者的公共函数是公开的,可能会被恶意调用,调用顺序也可能是任意的。任何人都可以查看智能合同中的隐私数据。
-
注意gas成本和区块gas限制。
-
注意,区块链上的时间戳是不精确的:矿工可以在几秒内影响交易执行的时间。
-
随机性是区块链上一个重要的特性,大多数产生随机数的方法在区块链上是具有博弈性的。
基本权衡因素
在评估智能合约系统的结构和安全性时,需要考虑多种基本的权衡。对于所有智能合约系统的普遍建议是,在这些权衡之间找到平衡点。
从软件工程的角度来看,理想的智能合约系统是模块化的,即重用代码而不是复制代码,以及支持可升级的组件。而从安全架构的角度来看,理想的智能合约系统可能同样会使用这种模式,尤其是面对更为复杂的智能合约系统。
然而,当安全性和软件工程最佳实践出现不一致时,也会有一些例外情况发生。而在每种情况下,可通过选择合约系统上的最佳性能组合来达到平衡,例如:
-
固定版本vs.可升级
-
整块化vs.模块化
-
复制vs.重用
固定版本vs.可升级
当多个资源 (包括此资源) 强调自身的延伸性时 (比如可中断的、可升级的或可修改的模式),那么就需要在延伸性和安全性之间找到一个平衡点。
延伸性增加了复杂性和潜在的受攻击性。如果智能合约系统在预先规定的有限时间内能够完成的功能非常有限,那么这时简洁性比复杂性要有效得多,例如,无治理的限时代币发售合约系统。
整块化vs.模块化
独立的整块化合约允许信息在本地识别和读取。虽然整块化合约一般不被重视,但对于数据和流的极端本地化存在争议,例如代码审计的效率优化。
与本文考虑的其他因素一样,在简单的短期合约中,安全性最佳实践趋向于与软件工程最佳实践相悖;而在更复杂的永久合约系统中,两者趋于相一致。
复制vs.重用
从软件工程的角度来看,智能合约系统希望能够在需要时最大化重用功能。在Solidity语言中,有许多重用合约代码的方法。实现代码重用的最安全的方式通常是:使用自己之前经过验证和部署的合约。
如果之前部署的合约无法使用,开发者通常就需要依靠复制功能了。OpenZeppelin的Solidity库尝试提供一些模式,使得安全代码可以在无需复制的情况下被重用。任何合约安全分析都必须将目标智能合约系统中还没有与风险资金建立相当信任级别的重用代码包含在内。
现如今,在以太坊上创建应用软件无疑是最令软件工程师激动的前沿领域,但这需要持续不断的威胁建模 (threat modeling)、安全审计,还需要做好周全计划以应对故障发生。
原文链接:https://media.consensys.net/the-smart-contract-security-mindset-a09f5f8f5f4f
来源:ETH中文网
比推快讯
更多 >>- 数据:过去 24h Binance 净流出 1.61 亿 USDT
- 哈萨克斯坦推出国家级加密储备基金,首笔投资为 BNB
- 不丹王国政府将 2011.23 枚 BTC 转移至新钱包,约合 2.2969 亿美元
- 美国劳工统计局:将在美国政府停摆期间暂停运营,不发布经济数据
- 今日美国比特币 ETF 净流出 4083 枚 BTC,以太坊 ETF 净流出 81358 枚 ETH
- 法资管巨头 Amundi 增持 MSTR 至 178 万股,持仓约 5.72 亿美元
- Algorand 基金会任命前 Ripple 工程师 Nikolaos Bougalis 为首席技术官
- 比特币财库公司 Mercurity Fintech 被纳入标普全球 BMI 指数
- 数据:USDC Treasury 在以太坊链上销毁约 3.5 亿枚 USDC
- 数据:BTC 全网合约持仓量 24h 增长 6.3%
- 花旗将其区块链平台接入美元清算,提供银行间即时跨境支付
- LQWD 斥资 156 万美元增持 14 枚 BTC,目前总计持有 252.5 枚 BTC
- Robinhood 股价止跌转涨 6.3%,此前部分高管遭披露进行内部股票交易
- 分析师:ETH 价格已重回 BitMine 成本线以上
- 美 SEC 要求 LTC、XRP、SOL、ADA 和 DOGE ETF 发行方撤回 19b-4 申请
- Canaccord 重申比特币矿企 Cipher Mining 买入评级,目标价上调至 16 美元
- 以太坊提币趋势延续,过去 24 小时 CEX 净流出 7601.58 枚 ETH
- 以太坊网络 Gas 费升至 15 gwei
- POAI 拟启动以 ATH 为核心数字资产库,获两笔 PIPE 融资约 3.44 亿美元
- 某 25 倍做空以太坊巨鲸追加仓位,爆仓价 4384.85 美元
- 比特币挖矿公司 MiningStore 完成 340 万美元战略贷款融资
- BitMine 以太坊财库规模已增至 2,650,900 枚 ETH
- 美股开盘加密板块普涨,Bitmine 上涨 2.4%
- 数据:过去 24 小时全网爆仓 3.57 亿美元,多单爆仓 9,247.24 万美元,空单爆仓 2.64 亿美元
- 迪士尼美股盘前跌超 1%,特朗普提征收 100% 关税
- TON Strategy Company 已质押 82%的 TON 代币储备,下月拟完成全部代币质押
- Fitell Corporation 拟在数字货币财库中配置 PUMP
- FG NEXUS:以太坊持仓量增至 50,770 枚 ETH
- 美股上市公司 Helius 提交注册修订将更名为 Solana Company
- Yearn Finance 新提案拟分配协议 90%收入至 YFI 代币质押用户
- 数字资产投资产品上周流出 8.12 亿美元
- 某地址花费 33.7 万美元买入 FF 现已浮盈 6.2 万美元
- Strategy 上周增持 196 枚比特币,花费 2210 万美元
- 美 SEC 与 CFTC 将召开 14 年来首次联合圆桌会议
- Sharps Technology 将使用 Crypto.com 平台管理其超 200 万枚 SOL 财库资产
- K Wave Media 获 Galaxy Digital 约 100 万美元股权投资
- 币安将下线 HIFIUSDT 与 BAKEUSDT 永续合约
- 波兰通过严格加密货币监管法案,最高可处 280 万美元罚款
- 贝莱德将 49,607.8 枚 ETH 和 340.5 枚 BTC 存入 Coinbase Prime
- 美股上市公司 NextGen Digital 拟拓展加密挖矿业务并与 Bittensor 网络集成
- Bitfinex 报告:加密市场格局仍受主要经济体监管变化和金融创新等因素影响
- 美联储理事沃勒:稳定币应纳入监管保护,并增加支付选项
- 高盛将全球股市评级上调至“增持”,看好经济前景
- BitMine 宣布持有 265 万枚 ETH 与总资产 116 亿美元
- 比特矿沉浸式技术公司以太坊持有量超过 265 万个代币
- Glassnode:今晨市场上涨清算大量开头,为上涨趋势注入新动能
- 美联储哈玛克:通胀或 2028 年才达标,政策需维持限制性
- Solana 链上稳定币总市值达 138 亿美元,创历史新高
- Amber 与中手游达成合作,将加速经典游戏 IP《仙剑奇侠传》的 RWA 计划
- DeepSeek-V3.2-Exp 模型正式发布并开源
比推专栏
更多 >>观点
比推热门文章
- 哈萨克斯坦推出国家级加密储备基金,首笔投资为 BNB
- 不丹王国政府将 2011.23 枚 BTC 转移至新钱包,约合 2.2969 亿美元
- 美国劳工统计局:将在美国政府停摆期间暂停运营,不发布经济数据
- BTC 周观察:非农周大考将至,市场逻辑突变…
- 标普指数多指标发出调整信号,警惕下跌风险!
- 今日美国比特币 ETF 净流出 4083 枚 BTC,以太坊 ETF 净流出 81358 枚 ETH
- 法资管巨头 Amundi 增持 MSTR 至 178 万股,持仓约 5.72 亿美元
- Algorand 基金会任命前 Ripple 工程师 Nikolaos Bougalis 为首席技术官
- 比特币财库公司 Mercurity Fintech 被纳入标普全球 BMI 指数
- 数据:USDC Treasury 在以太坊链上销毁约 3.5 亿枚 USDC