Cointime

扫码下载App
iOS & Android

智能合约开发的核心问题:确保每个阶段的安全性

作者:Roman Palamarchuk 编译:Cointime.com 237

智能合约是众多区块链应用的核心。虽然它们在促进去中心化系统信任方面具有不可变性,但这也凸显了在开发周期中严格的安全措施的必要性。

尽管智能合约有潜力,但也容易受到诸如重入攻击和闪电贷攻击等威胁。错误解释或计算错误也可能导致未预料的漏洞和攻击。

为了降低这些风险,我们将介绍安全智能合约开发的各个阶段,并提供可行的见解和指南。

安全智能合约开发概述

开发安全智能合约涉及几个关键阶段,每个阶段都需要仔细关注和理解。

1、安全智能合约设计考虑

我们将解释智能合约设计的基本原则,并强调理解区块链的重要性,保持设计简单和模块化等方面的重要性。

2、安全智能合约开发实践

我们将分享安全智能合约开发的有效实践。

3、测试和审查智能合约

本节将强调全面测试的重要性,并介绍各种工具来分析您的智能合约。

4、部署安全智能合约

我们将讨论在智能合约部署阶段的关键安全考虑因素。

5、维护智能合约安全

最后,我们将强调持续监控和更新以确保您的智能合约长期安全的必要性。

在每个阶段中,我们将融入真实世界的例子和见解,使智能合约开发中这些复杂的方面更易于理解和实施,无论您是经验丰富的Web3开发者还是好奇的企业家。

安全智能合约的设计注意事项

设计安全智能合约需要全面理解几个基本概念,并致力于一些设计原则。

1、对系统底层业务逻辑的深思熟虑设计是安全智能合约开发的关键。该逻辑应该是强大、清晰,并与项目目标一致。

设计这个逻辑不仅仅是模仿现有的市场解决方案,而是要理解它们、它们的优点、缺点,然后改进它们。这个过程涉及研究他人面临的类似挑战,向他们学习,并运用这些见解来提升自己的设计。

请记住,每个系统都是独特的,适用于一个系统的方法可能不适用于另一个系统。因此,对自己解决方案的批判性分析对于发现潜在陷阱至关重要。考虑到您的系统可能遇到的边缘情况以及您的智能合约将如何应对它们。警惕由您的实施引发的任何利用机会,如下面将描述的“滑点”示例。

2、掌握区块链技术的精髓是不可或缺的前提条件。这包括了解交易的工作原理、分布式账本的细节以及公钥和私钥的影响。此外,在开发安全智能合约时,全面理解第三方系统的集成至关重要。来自对UniswapV3集成审计的现实案例清楚地说明了当缺乏全面理解时可能发生的情况。

在这段代码片段中,使用_sellAmount作为输入金额进行了UniswapV3的交换操作,并将amountOutMinimum设置为零。此设置,即将最小输出代币数量(amountOutMinimum)设置为零,可能会导致一个常见的问题,即“滑点”。

在像Uniswap这样的去中心化交易所中,滑点表示预期交易价格与实际执行的交易价格之间的差异。它经常在市场波动较大时使用市价订单时出现。在这种情况下,由于没有设置下限,交易者可能因市场波动而收到少于预期的代币数量。

在测试过程中检测到这样的问题可能很棘手,因为它主要在特定的市场条件下显现。对于开发人员来说,发现这种漏洞同样具有挑战性。尽管进行了彻底的规划和严格的测试,但这些细微之处可能会被忽视,强调了审计在开发过程中的重要作用,以及需要专业的审计人员来发现和解决这些隐藏的风险。

3、简单性和模块化原则是智能合约设计的另一个支柱。简单性可以减少隐藏错误的风险,并增进开发人员和用户之间的理解。模块化将程序分割成单独的功能组件,可以方便地识别错误、简化故障排除,并提升开发的灵活性。

4、升级性也必须在初始设计阶段考虑。由于区块链是不可变的,智能合约升级需要实施策略,例如使用代理合约、隔离数据和逻辑,以及确保向前兼容性。

安全智能合约开发实践

经过精心规划系统架构、全面理解要使用的第三方服务以及深思熟虑的更新策略后,您现在已经准备好进入开发阶段了。

除了经常重复的安全开发提示,如:

1、使用最新的Solidity版本。

2、限制合约功能。

3、实施Assert、Require和Revert函数。

4、遵循Checks-Effects-Interactions模式。

5、谨慎分配角色及其权限。

6、测试智能合约。

我想在这个列表中添加自己的建议:

1、优先考虑Gas优化

智能合约具有Gas限制的特性,需要进行谨慎的优化。每次操作都会产生Gas成本,而这些成本可能非常不稳定。通过消除不必要的计算、选择合适的数据类型,并考虑外部合约调用的Gas成本来优化您的代码。考虑变量打包和评估循环操作的Gas效率。这不仅可以减少交互成本,还可以降低可能被利用的Gas耗尽错误的风险。我们将在下一节讨论检查Gas使用情况的工具。

2、小心处理第三方集成

如前所述,了解您计划使用的服务至关重要。了解每个变量的作用,审查潜在陷阱,并确保数据来源的相关性。例如,来自ChainLink的价格必须验证时间线,以防止其过时。

3、遵循官方的编码样式指南并使用NatSpec文档

根据官方的编码样式指南编写代码,并使用NatSpec进行文档编写可以显著提高代码的可读性。这对于可能需要审查您的代码的第三方开发者和审计人员尤其有益。这种增强的理解可以减少错误和安全问题的可能性。

测试和审查智能合约

在智能合约开发中,彻底测试的重要性不可低估。鉴于智能合约的不可变性和处理的高价值交易,任何被忽视的错误或漏洞可能导致不可逆转的后果。因此,单元测试至关重要,最好达到100%的代码覆盖率。这确保了每个函数、分支和代码行都经过了验证,降低了在实际环境中出现未预期行为或利用的风险。

要测试Solidity代码的覆盖率,我推荐使用Solidity Coverage插件。它与Solidity Gas Reporter(Hardhat内置的,也可作为其他工具的独立插件使用)配合使用,可以帮助您测试智能合约的执行情况、交易成本和其他方面在不同网络上的表现。

我还强烈推崇使用突变测试方法。这种方法对系统进行一系列“突变”或修改,生成略微不同的软件版本,并测试这些变种以评估测试是否能够检测到变化,从而衡量测试套件的质量并确定测试不足的软件区域。

SuMo是专为基于Solidity的智能合约设计的优秀突变测试工具。通过向源代码注入微小的错误或“突变”,并评估测试套件是否能够发现这些改动,SuMo可以评估您的测试的健壮性。这个过程有助于发现测试中的薄弱环节,从而提高整体质量。

SuMo有许多突变算子可供选择,包括传统的算子和专门针对Solidity的算子,可以根据项目需求进行开启或关闭。它还提供了突变测试流程的定制选项,可以选择特定的合约和测试用例进行突变。此外,SuMo的测试接口灵活多样,与不同的测试框架和区块链模拟器兼容。

您可以在GitHub上查看有关SuMo更详细信息的拉取请求:

https://github.com/MorenaBarboni/SuMo-SOlidity-MUtator

除上述实践外,强烈推荐使用分析工具,如Slither、Solgraph、Mythril、Echidna、MythX和Semgrep。这些工具有助于检测潜在的漏洞、可视化合约依赖关系、分析安全性质和扫描已知问题。利用这些工具可以对合约进行全面审查,增强整体安全性。

进行安全审计是确保智能合约健壮性的另一个重要步骤。审核将由独立机构对合约代码进行系统性审查,以发现任何漏洞或错误。这个过程在部署合约之前为其安全性和完整性提供了额外的保证。

安全智能合约的部署

智能合约的部署阶段与其开发同样重要。部署过程的完整性极大地影响合约的安全性和可操作性。因此,必须解决一些问题,以确保平稳和安全的部署。以下是一些建议:

1、首先使用测试网络

在主网上部署智能合约之前,始终先在测试网络(如Ropsten、Rinkeby、Kovan)上进行部署。这样可以在一个模拟主网但不带有真实资金风险的网络上进行测试。

2、多轮测试

在不同层次上进行多轮测试,包括单元测试、集成测试、系统测试和验收测试。这有助于在每个层次上发现任何错误或漏洞。

3、使用可重复、自动化的部署过程

可以使用可脚本化部署工具,如Truffle migrations,来实现这一点。目标是确保部署过程是确定性的、可重复的,并且尽可能地自动化。

4、添加时间锁定机制

将时间锁定的升级或更改纳入合约中。这样可以给用户留出时间以对变更提出异议,提供了额外的安全层。

5、限制函数权限

限制合约中每个函数的权限,特别是与部署和管理权限相关的函数。这是为了防止未经授权的访问并防范攻击。

6、验证源代码

部署后,在像Etherscan这样的区块链浏览器上验证合约的源代码。这个过程提高了透明度,因为任何人都可以阅读合约并了解其功能。

7、紧急停止机制

在合约中加入“紧急停止”机制。这样,在检测到异常或错误时可以暂停合约的某些功能。

维护智能合约安全性

随着进入部署后阶段,我们必须认识到保持安全性不是一次性任务,在部署智能合约后就结束了。相反,这是一个需要持续监控和持续维护的持续过程。以下是一些有效的策略,用于管理和维护已经部署的智能合约的安全性:

1、实施实时跟踪系统以对智能合约进行持续监控是一种有效的策略。诸如Hacken Extractor之类的系统可以提醒您任何异常活动,例如交易量突然激增、可疑交易或合约余额的显著变化。监视合约的燃气使用情况也可以为其与网络的互动提供有价值的见解,帮助发现潜在的优化区域或问题存在。

2、部署后安全维护的另一个重要方面是有效利用漏洞赏金计划。通过建立漏洞赏金计划,您可以激励社区协助发现和报告智能合约中的漏洞。像HackenProof这样的平台提供专门的服务来管理这些计划,确保安全的环境进行此过程。这不仅增强了合约的安全性,还通过展示您对安全的承诺来建立与用户的信任。

3、最后,及时了解生态系统中发现的最新漏洞至关重要。像以太坊安全社区这样的平台会整理和维护最新的智能合约漏洞列表。定期检查这些平台或订阅其更新可以让您了解潜在威胁。

总之,保持智能合约安全的关键在于对监控、审计、更新的持续循环,并在团队中培养以安全为先的文化。

结论

设计、开发、测试和审查、部署以及维护这五个关键阶段都需要独特的安全考虑。深思熟虑而坚固的设计、勤奋的开发、彻底的测试、谨慎的部署和持续的维护都是这个过程的关键方面。此外,了解生态系统中最新的漏洞情况,并通过诸如漏洞赏金计划等倡议利用社区的力量,可以显著增强智能合约的安全性。

最终,安全地创建、部署和维护智能合约需要牢固的理解、细致的规划、全面的测试和持续的警惕。由于不完善的安全性可能导致财务损失或声誉受损等后果,这些努力变得至关重要。凭借这些见解和实践,开发人员和团队可以为不断发展的区块链技术领域做出安全的智能合约贡献。

评论

所有评论

推荐阅读

  • EXOR集团 :拒绝Tether公司收购尤文图斯股份的提议

    EXOR集团 :拒绝Tether公司收购尤文图斯股份的提议,重申无意出售尤文图斯股份。 此前报道,加密货币巨头Tether公司对于收购尤文图斯俱乐部的计划非常认真,他们准备再次开出一份超过20亿欧元的新报价。

  • Tether 开出总估价超过 20 亿欧元的新报价收购尤文图斯

    加密货币巨头 Tether 公司对于收购尤文图斯俱乐部的计划非常认真,他们准备再次开出一份超过 20 亿欧元的新报价。昨天 Tether 已经向 Exor 董事会提交了一份报价,意图收购阿涅利家族控股公司所持有的尤文图斯 65.4% 股份,这一消息由首席执行官保罗-阿尔多伊诺通过社交媒体公布,但这仅仅是谈判的开始。

  • American Bitcoin比特币储备过去7天增加约623枚,现仓位达4941枚BTC

    此前曾披露分析“1011内幕巨鲸”的链上分析师Emmett Gallic在X平台发文披露特朗普家族支持的加密矿企American Bitcoin比特币储备更新数据,过去七天增加约623枚BTC,其中约80枚来自于挖矿收入,542枚来自于公开市场的战略收购,截至目前其比特币总持有量增至4941枚,当前市值约合4.5亿美元。

  • 美国现货以太坊ETF昨日净流出1940万美元

    据TraderT监测,美国现货以太坊ETF昨日净流出1940万美元

  • 华夏基金香港在Solana上推出亚洲最大代币化货币市场基金

    12月12日消息,华夏基金香港(ChinaAMC HK)产品与策略负责人 Katie He 在 Solana Breakpoint 大会上表示,将推出亚洲首个且规模最大的代币化货币市场基金,涵盖港币(HKD)、美元(USD)和人民币(RMB)计价,将传统货币市场工具代币化,为投资者提供安全、链上访问稳定收益的机会,具有完全透明度和实时结算。经过数月与监管机构及 OSL 等伙伴的合作,这一创新将自香港扩展至更广阔地区,并原生部署到 Solana 区块链上。

  • 加拿大皇家银行已购入77,700股American Bitcoin股票

    据市场消息:价值1万亿美元的加拿大皇家银行已购入77,700股American Bitcoin ($ABTC)股票,价值约15万美元。该比特币矿企由特朗普家族成员Eric Trump支持。

  • 中国人民银行:继续实施适度宽松的货币政策,推进人民币国际化

    中国人民银行党委召开会议,会议纪要第三点指出:继续实施适度宽松的货币政策,加快推进金融供给侧结构性改革。把促进经济稳定增长、物价合理回升作为货币政策的重要考量,灵活高效运用降准降息等多种货币政策工具,把握好政策实施的力度、节奏和时机,保持流动性充裕,促进社会综合融资成本低位运行,加强对实体经济的金融支持。畅通货币政策传导机制,优化结构性货币政策工具运用,加强与财政政策的协同,激励和引导金融机构加力支持扩大内需、科技创新、中小微企业等重点领域。保持人民币汇率在合理均衡水平上的基本稳定。会议纪要第五点指出:稳步推进金融高水平开放,维护中国国家金融安全。践行全球治理倡议,积极参与和推进全球金融治理改革完善。务实开展金融外交和多双边货币金融合作。推进人民币国际化。持续建设和发展多渠道、广覆盖的人民币跨境支付体系。稳步发展数字人民币。

  • 日本央行据悉将进行更多加息 部分官员认为中性利率高于1%

    据知情人士透露,日本央行官员认为,在本轮加息周期结束前,利率很可能升至0.75%之上,这表明在下周加息之后,可能还会有更多次加息。这些人士称,官员认为,即使加息至0.75%,日本央行仍未达到中性利率水平。部分官员已认为1%仍低于中性利率水平。知情人士表示,即便日本央行根据最新数据更新中性利率估算,目前也并不认为该区间会显著收窄。目前日本央行对名义中性利率区间的估计约为1%至2.5%。知情人士称,日本央行官员认为该区间上下限本身也可能存在误差。(金十)

  • Nexus 启动“节点之光·先锋理财周”,打造节点用户专属通道

    Nexus 12月12日宣布即将启动为期五天的 “节点之光·先锋理财周”,以“节点身份金融特权” 为核心理念,为生态核心参与者开启一段独立于全平台的专属理财周期。此次活动仅限节点用户参与专属理财包认购,并为随后上线的全平台理财与 NexSwap 注入市场期待。

  • 美 SEC 主席:DTC 参与者可将代币化证券转入其他参与者的注册钱包

    美国证券交易委员会(SEC)主席 Paul Atkins 在 X 平台发文表示,美国金融市场即将向链上转型并将优先考虑创新并积极采用新技术,SEC 已向美国存托信托与清算公司(DTC)发布了一封不采取行动的信函,链上市场将为投资者带来更高的可预测性、透明度和效率,现在 DTC 参与者可以直接将代币化证券转入其他参与者的注册钱包,这些交易将被 DTC 官方记录跟踪。