番外篇-如何开发智能合约入门

今天咱们聊聊如何开发智能合约,非常入门的分享~

1. 如何开发智能合约

1.1. 基本流程 & 主流工具

1.1.1. 编写合约代码
  • Solidity仍然是一骑绝尘(EVM)
  • Vyper是不太活跃语言,python语法(EVM)
  • Rust不能应用在EVM的区块链。然而Rust可以部署到Solana、Terra等链上,或者在Polkadot构建区块链应用。Rust是一种性能良好的通用语言,甚至在智能合约之外使用

番外篇-如何开发智能合约入门_第1张图片

1.1.2. 底层依赖
  • Openzeppelin
    • https://openzeppelin.com/
    • Openzeppelin巩固了自己作为 “solidity标准库 ”的地位
    • Openzeppelin是一套已经写好的智能合约,不需要重新发明轮子。使用他们已经审计过的可扩展智能合约,可以节省无数时间
  • Chainlink
    • https://chain.link/
    • Chainlink是预言机里的NO.1

番外篇-如何开发智能合约入门_第2张图片

  • 节点服务商
    • 封装了底层链的各种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)

番外篇-如何开发智能合约入门_第3张图片

1.2.2. 编译合约代码

1.2.3. 部署合约

番外篇-如何开发智能合约入门_第4张图片

如果“环境”选择了"Injected Network",会自动连接钱包,钱包切换网络,则可以将合约部署到该网络上!部署时候会触发交易,产生Gas费

番外篇-如何开发智能合约入门_第5张图片

1.2.4. 执行合约(合约交互)

这里是UI的交互,主流的就是代码方式了

1.2.5. 在浏览器中查看交易明细

https://goerli.basescan.org/tx/0x26...9db22

番外篇-如何开发智能合约入门_第6张图片

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);

你可能感兴趣的:(Web3,区块链,智能合约)