今天咱们聊聊如何开发智能合约,非常入门的分享~
1. 如何开发智能合约
1.1. 基本流程 & 主流工具
1.1.1. 编写合约代码
- Solidity仍然是一骑绝尘(EVM)
- Vyper是不太活跃语言,python语法(EVM)
- Rust不能应用在EVM的区块链。然而Rust可以部署到Solana、Terra等链上,或者在Polkadot构建区块链应用。Rust是一种性能良好的通用语言,甚至在智能合约之外使用
1.1.2. 底层依赖
- Openzeppelin
-
- https://openzeppelin.com/
- Openzeppelin巩固了自己作为 “solidity标准库 ”的地位
- Openzeppelin是一套已经写好的智能合约,不需要重新发明轮子。使用他们已经审计过的可扩展智能合约,可以节省无数时间
- Chainlink
-
- https://chain.link/
- Chainlink是预言机里的NO.1
- 节点服务商
-
- 封装了底层链的各种API & 节点计算资源
- Top服务商:Alchemy、QuickNode(很全,Base链推荐)、Infura(当前主导地位)、Blockdaemon(Base链推荐)、Blast(Base链推荐)
1.1.3. 编译 & 测试 & 部署 框架
- Hardhat
-
- 目前最主要的智能合约开发框架
- 基于javascript和solidity的开发框架
- Foundry & DappTools
-
- Dapptools是一个专注于命令行的工具,Foundry是用Rust编写的Dapptools,是Dapptools的继承者
- Foundry2022年才诞生,发展速度很快,测试运行速度也很快,提升开发效率
- Brownie & Apeworx
-
- 这两个都是基于Python的,同时支持solidity和vyper
- Brownie已经处于维护模式,Apeworx即将成为Brownie的继承者
- Remix
-
- 最适合初学者的平台,Web IDE
- 适合快速尝试想法、分享
1.1.4. 安全分析/审计
代码发布到区块链上时,审计是至关重要的,因为任何人都可以查看,一旦它发布了,就有可能被利用!因此,有一些工具可以帮助我们确保在代码中减少错误,这是非常重要的。这个领域已经出现了一些工具,使我们的智能合约更加安全。
- Eth Security Toolbox
- Echidna
- Slither
- Mythril
- Code4rena
- Immunefi
1.1.5. 监控运维
- Openzeppelin的Defender
- Tenderly
1.2. 基于Remix的Demo
https://remix.ethereum.org
1.2.1. 编写合约代码(Solidity)
1.2.2. 编译合约代码
1.2.3. 部署合约
如果“环境”选择了"Injected Network",会自动连接钱包,钱包切换网络,则可以将合约部署到该网络上!部署时候会触发交易,产生Gas费
1.2.4. 执行合约(合约交互)
这里是UI的交互,主流的就是代码方式了
1.2.5. 在浏览器中查看交易明细
https://goerli.basescan.org/tx/0x26...9db22
1.3. 其他Demo
- Hardhat (纯代码交互了,不再有UI界面了)
-
- https://hardhat.org/tutorial/boilerplate-project
2. 进一步了解开发合约
2.1. 合约本身代码开发(Solidity)
- Solidity官方文档
-
- https://docs.soliditylang.org/zh/latest/index.html
- 比较有趣的学习课程
-
- #1 Solidity Tutorial & Ethereum Blockchain Programming Course | CryptoZombies (Solidity的部分比较有意思,其他的一般)
2.2. 合约交互开发
2.2.1. 智能合约交互的代码编写
- 以太坊节点只能识别一种叫做 JSON-RPC 的语言。这种语言直接读起来并不好懂。当你你想调用一个合约的方法的时候,需要发送的查询语句将会是这样的:
- 幸运的是 Web3.js 把这些令人讨厌的查询语句都隐藏起来了, 所以你只需要与方便易懂的 JavaScript 界面进行交互即可。你不需要构建上面的查询语句,在你的代码中调用一个函数看起来将是这样:
2.2.2. 合约交互背后是谁提供服务(节点服务商,也叫Provider)
- 在 Web3.js 里设置 Web3 的 Provider(提供者) 告诉我们的代码应该和 哪个节点 交互来处理我们的读写。这就好像在传统的 Web 应用程序中为你的 API 调用设置远程 Web 服务器的网址。
- 你可以运行你自己的以太坊节点来作为 Provider。 不过,有一个第三方的服务,可以让你的生活变得轻松点,让你不必为了给你的用户提供DApp而维护一个以太坊节点— Infura.(当然还有其他的)
2.2.3. 合约对外交互的关键
- Web3.js 需要两个东西来和合约对话: 它的 合约地址 和它的 合约ABI。
-
- 合约地址:合约部署后就会生成一个合约地址
- 合约ABI:ABI 意为应用二进制接口(Application Binary Interface)。 基本上,它是以 JSON 格式表示合约的方法,告诉 Web3.js 如何以合同理解的方式格式化函数调用。
- 实例化合约
-
- 一旦有了合约的地址和 ABI,你可以像这样来实例化 Web3.js。
{
"jsonrpc": "2.0",
"method": "eth_sendTransaction",
"params": [{
"from": "0xb60e8dd61c5d32be8058bb8eb970870f07233155",
"to": "0xd46e8dd67c5d32be8058bb8eb970870f07244567",
"gas": "0x76c0",
"gasPrice": "0x9184e72a000",
"value": "0x9184e72a",
"data": "0xd46e8dd67c5d32be8d46e8dd67c5d32be8058bb8eb970870f072445675058bb8eb970870f072445675"
}],
"id": 1
}
CryptoZombies.methods.createRandomZombie("Vitalik Nakamoto 🤔")
.send({ from: "0xb60e8dd61c5d32be8058bb8eb970870f07233155", gas: "3000000" })
// 实例化
myContractvar myContract = new web3js.eth.Contract(myABI, myContractAddress);