Solidity 智能合约入门

Solidity 是链上智能合约的开发语言,链上智能合约相当于传统行业的后端,链上应用基本都是由合约 + 前端组成的,虽然不推荐,但部分链上应用也会加入后端进行数据存储,以降低用户的使用成本。

Solidity 这门开发语言并不复杂,只需要您稍微有一点儿编程基础,英文词汇量达到中学生水平,都能看懂基本的合约代码逻辑即可。

最开始强烈推荐先入门 ERC20 和 ERC721 ,理解之后,再去看关联的 ERC1155 、ERC4907 等以太坊标准,都不会觉得有什么理解上的太大压力。

除此之外,以太坊标准 ERC 为开发者提供了大量开源的合约接口,开发者可轻松用于构建各类链上实用功能。Solidity 智能合约开发,大体上就是 看懂(ERC) + 活用(ERC+开源链上合约代码) + 简单的逻辑调整改造(目的是贴合自己实际需求) 即可完成 ✅。

进行简单的合约开发,推荐您用 Remix IDE;如果您是资深开发人员,更习惯于命令行式的开发和调试,可以选择 Truffle 套件。

能够看懂大部分 ERC 之后,可以尝试看一些成功的链上项目了解更多链上应用的全貌,之后就能尝试自己构建链上应用。推荐您先从 0 开始仿写刚刚学习完的链上项目,就选择简单的即可,多完成几个项目仿写之后,相信您在自由构建的路上,应该不会有太大的困难。但需要注意的是,智能合约中像Dos攻击、短地址攻击、交易顺序依赖、伪随机等被Q烂的漏洞,也需要做到心中有数哦。

下面我会介绍两个开发IDE/工具套件,和推荐入门学习的链上项目,供您参考。

Remix —— 新手友好的可视化 IDE

Remix 是以太坊提供的可视化 Solidity 智能合约开发 IDE ,页面新手友好,在实现合约编辑、一键部署上链、合约接口测试、bug单步调试等全套功能的同时,界面简洁大气,用户还有多种前端风格可选,实用性和美观性上都得到了很好的满足。

Truffle —— 进阶联调抗打小能手

Truffle 套件能够实现 Remix 的功能,是命令行式的交互模式。Truffle 允许你以脚本的模式构建测试文件,后面合约代码的修改,只需一键执行测试文件即可,有时测试文件也需要配合进行微调。如果测试时您用的是 Remix,那可能需要在每次代码调整后,重新手动执行全套的测试流程。在自动化测试方面,Truffle 拔得头筹。

使用 Truffle 时,您可能还需要 Ganache 的辅助支持,以更方便、快捷地获得及查看测试地址的余额信息及链上交易状态。

Dapp 入门

Dapp 的入门学习首先推荐两个使用了 REC721 标准的链上项目:加密猫——CryptoKitty 和 阿蟹——Axie Infinity。CryptoKitty 的合约逻辑非常简单,有兴趣的伙伴可以看一下我的这篇博文教程。Axie Infinity 的合约逻辑涉及权限控制,会稍微复杂一丢丢,我的博文教程也在计划之中了,大家敬请期待。

Defi 入门

Defi 主要是使用 REC20 标准的链上项目,推荐你看借贷相关的 Compound、Aave,去中心化交易所相关的 Uniswap 入门。他们可比永续合约、衍生品、期权要友好的多,不需要你有太多的金融知识。

AAVE 是基于 Compound 构建的,目前 AAVE 的合约已经更新到了第三个版本,整体给我的感觉就是第一个版本比较混乱,学习的过程中内心无数次想要尖叫,学完之后就会觉得,也就那样吧。第二个版本代码相对整齐了很多,推荐读代码时容易被各种繁杂内调搞到头大的小伙伴可以略过 V1 直接从 V2 入门。第三版本的代码整洁得就像军事化管理下的干净,不推荐新手直接阅读,容易陷入迷宫困境。

上诉三个 Defi 项目的博文教程也在我的计划之中,V1 的 AAVE 应该会是最先推出的,大家敬请期待。

结语

以上就是我推荐的 Solidity 智能合约技术成长之路,从 ERC 标准入门,然后学习常用的开发工具,接着阅读成功链上应用的开源代码,然后可以开始自己尝试仿写构建,最后在了解常见漏洞规避方法的基础上,就能轻松踏上合约开发之路了。

记得,合约开发 == 看懂(ERC) + 活用(ERC+开源链上合约代码) + 简单的逻辑调整改造(目的是贴合自己实际需求)

✅ 下课。