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

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

结论

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

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

评论

所有评论

推荐阅读

  • IPO在即,灰度创始人Barry Silbert回归出任董事会主席

    Grayscale Investments 在提交保密 IPO 申请后,宣布四项高管任命并迎回创始人 Barry Silbert 担任董事会主席。新任命的高管包括:首席运营官 Diana Zhang、首席营销官拉蒙娜·波士顿 Ramona Boston、首席传讯官 Andrea Williams、首席人力资源官 Maxwell Rosenthal。四位高管都将向灰度首席执行官 Peter Mintzberg 汇报,他们均来自传统金融巨头,包括桥水基金、阿波罗全球管理、高盛和城堡投资。 Barry Silbert 于 2013 年创立灰度,于 2023 年底辞去灰度董事长一职,此次将接替 Mark Shifke 担任董事会主席,Shifke 将继续留任董事会,目前董事会成员已增至五人。公司表示正在考虑增加独立董事。 Barry Silbert 表示:「我很荣幸能够在公司乃至更广泛的数字资产生态系统的关键时刻重新加入灰度董事会。我始终坚信公司的长期定位以及引领公司前进的领导团队。」

  • SharpLink Gaming增持18,680枚以太坊,总持有498,884枚

    据链上分析师 Onchain Lens 监测,SharpLink Gaming(股票代码:SBET)今日再次增持18,680枚以太坊,价值约6,663万美元。此次增持后,该公司以太坊储备总量达到498,884枚,总价值约18亿美元。

  • Bullish向美国证交会提交IPO申请,拟募资6.29亿美元

    数字资产交易所Bullish及其子公司CoinDesk已向美国证券交易委员会(SEC)提交首次公开募股(IPO)申请。根据申请文件,Bullish计划发行2030万股,发行价区间为28-31美元/股,最高募资金额为6.29亿美元,对应公司估值约42亿美元。 Bullish业务范围包括数字资产现货交易、杠杆交易和衍生品交易,同时为稳定币发行机构提供流动性服务。财务数据显示,该公司2025年第一季度数字资产销售额达8020万美元,净亏损3.49亿美元。Bullish曾于2023年以7260万美元收购加密货币媒体平台CoinDesk。

  • 欧盟将对美国的贸易反制措施暂停6个月

    市场消息:欧盟将对美国的贸易反制措施暂停6个月

  • 去中心化操作系统 OpenMind 完成 2000 万美元融资,Pantera Capital 领投

    智能机器去中心化操作系统 OpenMind 宣布完成 2000 万美元融资,Pantera Capital 领投,Coinbase Ventures、Digital Currency Group 和 Ribbit 等参投。 据悉,这家初创公司正在开发一款名为 FABRIC 的“硬件无关”操作系统,旨在支持“智能机器融入日常生活”。该协议为支持人工智能的机器人提供了一种通信和协调的方式。

  • 观点:LetsBonk 短期称霸,PumpFun 或将更换战略实现逆袭

    Memecoin 市场衰退,PumpFun 战略转型或成最大赢家。

  • 加强个人境外收入监管 境外买卖股票收入也要缴税

    《金融时报》刊文,据了解,近期有纳税人收到了税务部门通知,告知其需要依法办理境外所得申报并缴纳相应税款。“根据我国个人所得税法,个人股票交易所得属于财产转让所得,应当适用20%的税率按次征收。其中,个人在境内二级市场的股票交易所得暂免征收个人所得税;在境外直接进行股票交易所得没有免税规定,需要在取得所得的次年申报纳税。”吉林财经大学税务学院院长张巍解释说。为了更加合理的征收,我国税务部门在征管时,允许纳税人按照纳税年度盈亏相抵,但不允许跨年互抵。依法纳税是每个公民应尽的义务。个人未申报或者未如实申报境外所得,除了会被税务机关要求补缴税款外,还会被加收滞纳金,情形严重的还可能被稽查部门立案检查,将面临税务处罚。纳税人如果发现自己此前申报个税时,存在少报、漏报境外所得的,要及时补正。

  • 美国SEC文件显示特斯拉批准向马斯克授予9600万股股票奖励

    美国SEC文件显示:特斯拉(TSLA.O)批准向马斯克授予9600万股股票奖励,马斯克将按每股23.34美元的价格购买已获授股票。

  • Binance Alpha:持有至少 200 币安 Alpha 积分的用户可申领 1000 个 DARK 代币空投

    据官方公告,Binance Alpha 是首个上线 DarkStar(DARK)的平台,Alpha 交易将于 2025 年 8 月 4 日 20:00(UTC+8)开始。 交易开始后,持有至少 200 个币安 Alpha 积分的用户可申领 1000 个 DARK 代币空投。先到先得。若活动未结束,则分数门槛将每小时自动降低 15 分。 请注意,申领空投将消耗 15 个币安 Alpha 积分。用户需在 Alpha 活动页面于 24 小时内确认申领,否则视为放弃领取空投。

  • 香港《稳定币条例》正式生效:储备资产须全额覆盖流通面值

    8月1日,香港《稳定币条例》正式生效,建立起稳定币发行人牌照制度,完善香港对虚拟资产活动的监管框架。大湾区国际资讯科技协会会长杨德斌表示,如今国际上稳定币的发展已经达到一定规模。香港在这个时点推出《稳定币条例》,是在监管方面与时俱进的体现。与国际标准接轨,中国香港在制定稳定币相关规定时也力求与全球其他国家和地区的标准接轨。根据香港《稳定币条例》,持牌人必须确保其发行的指定稳定币的储备资产的市值,始终不低于该类稳定币尚未赎回且流通中的面值。持牌人应考虑储备资产的风险状况,确保有适当的超额抵押以覆盖市场风险。