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

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

结论

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

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

评论

所有评论

推荐阅读

  • Web3 AI平台ChainML完成620万美元种子轮扩展融资,Hack VC领投

    Web3 AI 平台 ChainML 宣布完成 620 万美元种子轮扩展融资,Hack VC 领投,Inception Capital、HTX Ventures、Figment Capital、Hypersphere Ventures 和 Alumni Ventures 等参投,该平台还宣布推出其代理基础层 Theoriq。

  • 元宇宙项目 Baby Shark Universe 以 3400 万美元估值完成种子轮融资

    元宇宙项目 Baby Shark Universe 宣布完成种子轮融资,估值为 3400 万美元,投资方包括 Animoca Brands、CREDIT SCEND、Sui Foundation、Comma3 Ventures、Creditcoin、GM Ventures、Neuler、Notch Ventures、X+ 和 Planetarium 等。具体金额暂未披露,所筹集的资金将用于开发和全球营销。

  • 5月13日晚间要闻速递

    1. BTC 突破 63000 美元

  • 香港证券交易所确认加密货币ETF对中国大陆投资者不可用

    据 Coindesk 报道,香港证券交易所确认加密货币ETF对中国大陆投资者不可用,香港的加密货币 ETF 由于其独特的实物赎回模式,将提供绕过中国大陆资本管制的手段。

  • Web3社交基础设施UXLINK ​​​​​​完成500万美元融资

    Web3 社交基础设施 UXLINK 宣布完成新一轮 500 万美元融资,由SevenX Ventures、INCE Capital和HashKey Capital领投,据悉,目前UXLINK 的融资总额已突破 1500 万美元。

  • 中国警方破获价值 2.96 亿美元非法加密货币交易案

    中国警方在吉林省磐石市打击了一个非法加密货币交易团伙,逮捕了六名涉案人员。他们经营的“地下银行”利用加密货币的匿名性和跨境转账特点,为韩元和人民币之间的非法兑换提供服务,涉及金额达21.4亿元人民币(约合2.96亿美元)。被捕人员中包括韩国采购代理商、电商公司和进出口企业。

  • 香港证监会告诫公众提防名为“LENA Network”的可疑拟资产投资产品

    香港证监会告诫公众提防名为“LENA Network”的可疑虚拟资产投资产品,该产品涉及与虚拟资产相关的质押及借贷安排,并声称向投资者提供高回报。该投资产品并未获证监会认可向香港公众发售。证监会注意到,香港公众可透过互联网取览关于该产品的资料及接触该产品。证监会提提切忌尽信那些“好得令人难以置信"的投资机会,及在作出投资决定时保持警惕。

  • 香港证监会:《打击洗钱条例》适用于虚拟资产业界

    有消息披露香港“虚币转ETF”机制惹洗钱忧虑,业界称需KYT(Know Your Token)等审查难度很高,有内地背景人士正尝试小额度“虚币转ETF”交易,借此机会透过人头帐户等形式“洗白”自己持有的以太币、比特币,并已部署部分虚币至香港的虚币交易所,未来将视情况决定是否增资。 香港证监会回应相关问题时强调,ETF产品运作当中,整个虚拟资产生态的每个环节,包括基金公司、托管行、资产交易平台、参与券商,等均需为持牌或认可机构,并须严格遵守资产保管、流动性、估值、信息披露、投资者教育等要求。证监会《打击洗钱条例》亦订明金融机构和指定非金融企业及行业人士,须遵守客户尽职审查及备存纪录规定,相关规定适用于虚拟资产业界。

  • TON社区成员:部分TON钱包收到“888”开头的虚拟账号NFT,系钓鱼项目

    据 TON 官方社区成员披露,TON 钱包多出一个近期爆火的“888”开头虚拟号码的 NFT,但每次转出的手续费高达 1 TON,系钓鱼项目更改 Gas 所导致。

  • friend.tech的发币过程有多乱?

    SocialFi平台friend.tech的代币空投过程混乱,代币上线后不久甚至短时飙升至169美元.