前言
这是2022年写的文章,用ERC777标准实现的,后来官方声明ERC777难用且不安全被弃用了:https://github.com/ethereum/ethereum-org-website/pull/7340。就连最新的openzeppelin也删除ERC777标准的合约,所以本文改为ERC20标准来实现https://eips.ethereum.org/EIPS/eip-20,但是文件名明还是保持不变。
一、前期准备
发布智能合约(开发的程序)是需要交易费的,所以我们一般在测试链进行。以太坊升级到2.0后,有些测试网络就不能使用了,goerli
、sepolia
这两个测试网可以用。当然你也可以去Infura
上(https://infura.io/)注册一个账号,这样就可以在网站提供的多种网络上测试。
我个人推荐sepolia上测试,因为https://etherscan.io/区块链浏览器(可查询主链和测试区块链上所有交易、账户余额,代币等)国内不能直接访问。但https://sepolia.otterscan.io/ 这个网站国内直接可以访问,查询sepolia测试链上的信息,更方便;相当于前者的简化版。
二、开发环境搭建
2.1 vscode及Truffle 插件安装
vscode
对前端开发人员来说一定不陌生,尤其是Vue3
开发使用vscode很方便。下载地址:https://code.visualstudio.com/ ,安装过程就不介绍了。
安装好vscode之后,点击顶部菜单“查看”-“扩展”,在左上角文本框中输入“truffle”并回车,点击truffle for vscode
插件,然后再点击“安装”按钮即可。我已经安装了,所以显示的是“卸载”按钮。
当然你也可以用官方的remix在线开发工具:https://remix.ethereum.org/,我用起来感觉不是很方便。
2.2 安装MetaMask钱包
因为发布智能合约(代币程序)需要交易费的,所以就需要用到钱包和测试币。MetaMask
轻钱包就很适合,它以浏览器插件的形式运行,主流浏览器都支持,看你喜欢下载哪一个https://metamask.io/download/ ,我用的是chrome
插件。具体安装过程不介绍了,网上很多教程。如果第一次创建钱包账户的话,会生成12个助记单词,你要把这些记下来(顺序不能错)并妥善保管,后面要用到。助记词或私钥就相当于你的银行卡密码,一旦泄露别人就能转走你的虚拟资产,如果只有测试币那倒没关系。
点击MetaMask钱包右上角的图标(见上图),在弹出菜单中点击“设置”,再点击“高级”,然后把“显示测试网络”这个选项打工,默认是关闭的。
然后回到钱包主页(如下图),点击 1的位置就可以切换到测试网络了。点击红框内的地址,将你的钱包地址复制到剪贴板,然后去弄一些测试币回来。
2.3 获取sepolia链测试币
直接点击上图中的“购买”按钮,在弹框中点击“购买测试币”,在弹出的页面中(如下图),1的位置输入你的钱包地址,点击 2处的复选框进行验证(防止机器人),验证通过后点击3处的的绿色按钮,等待一会儿就能得到0.5个测试币。
也可以去这个页面获取一下(https://sepolia-faucet.pk910.de/ ),这个用你的CPU模拟挖矿,需要时间久一点,最多能获取2个测试币,基本够用了。获取成功后,在钱包中就能看到你的余额发生变化了。
2.4 nodejs和npm安装
前端的类库一般是用npm工具来管理,就像后端的maven一样。
http://nodejs.cn/download/ 这里下载一个安装,安装过程这里不介绍了。安装后,在命令行或终端中输入 npm -v 命令查看到版本号即为安装成功。
三、开发实战
想必你一定急于开发了,其实有开源的代码,继承修改一下就好了,不需要写多少代码。关于Solidity的学习,可以看我的上一篇文章:https://www.jianshu.com/p/1e688582ef44
3.1 新建项目
先新建一个空的目录作为项目的根目录,打开vscode开发工具,然后点击菜单“查看”-“命令面板”,在输入框中输入“truffle”,点击“Truffle: New Solidity Project” 命令,再点击“Create empty project”创建一个空的项目,会弹出对话框选择一个目录来存储代码。
3.2 安装类库
项目创建完成之后,再点击菜单“查看”-“终端”,打开终端面板(如下图1)。当然你也可以在windows
运行cmd
“命令提示符”或“终端”程序,切换到项目目录下,执行下面的命令:
# 设置国内镜像,提高下载速度
npm config set registry https://registry.npm.taobao.org
npm install -g truffle
npm i -g ganache
npm i @openzeppelin/contracts
npm i @truffle/hdwallet-provider
第一个npm config
命令是配置下载镜像,提高下载速度,如果已经执行过可以忽略。
@openzeppelin/contracts
是开源的solidity代币或NFT
代码库,在node_modules\@openzeppelin\contracts\token\ERC20
目录下,可以看到等下要用到的代码。
@truffle/hdwallet-provider
是一个钱包工具类,类似前面安装的MetaMask钱包。
点击4处资源管理器图标,可以看到代码的目录结构。
3.3 代码编写
3.3.1 contacts/Elwin777.sol
右击contacts目录,新建文件,输入:Elwin777.sol并回车,你也可以用别的文件名。输入文件内容如下:
// SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;
import "@openzeppelin/contracts/token/ERC20/ERC20.sol";
contract Elwin777 is ERC20 {
constructor(uint256 initialSupply) ERC20("Elwin777", "EZ7") {
_mint(msg.sender, initialSupply * (10 ** 18));
}
}
只有几行代码,之前学solidity语言用了很久,现在觉得有点浪费时间了。合约名称也是Elwin777和文件名保持一致。导入了openzeppelin/contracts类库中的ERC20.sol文件,并继承了这个合约。
合约只有一个构造函数,initialSupply参数是初始发行代币数量;其中ERC20("Elwin777", "EZ7")这一行调用父合约中的构造函数,第一个参数为代币名称,第二参数是代币的符号(缩写),这两个参数很重要,自己修改成你喜欢的名称。
3.3.2 migrations/777_deploy.js
然后在migrations目录下新建777_deploy.js文件,这是一个部署js文件,文件名中下划线前面一定要为数字才能在部署时被执行,如果migrations目录下有多个文件,按前面数字从小到大的顺序依次执行。文件内容如下:
const myToken = artifacts.require("./contracts/Elwin777.sol");
module.exports = async function (deployer, network, accounts) {
await deployer.deploy(myToken, 1000000, []);
};
代码也很少,第一行是导入Elwin777.sol合约文件,deployer.deploy(myToken, 1000000)
;为部署导入的文件。后面两个参数即为Elwin777.sol文件的构造函数参数,这里的初始发行量设为100万。
3.3.3 truffle-config.js
修改项目根目录下的truffle-config.js文件,文件内容如下:
var HDWalletProvider = require("@truffle/hdwallet-provider");
var MnemonicPhrase = "hello cat shed ……"; //填入你的MetaMask钱包助记词
var ProviderUrl ="https://rpc.sepolia.org"; //测试网络RPC接口地址,也可以填入infura项目地址
var AddressIndex=0; //钱包中的第几个地址,从0开始;如果钱包中只有一个地址,可以去掉这个参数
module.exports = {
networks: {
sepoliaTestNet:{
network_id:"*",
provider: function() {
return new HDWalletProvider(MnemonicPhrase, ProviderUrl, AddressIndex);//使用助记词
},
network_id: "*", // 匹配任意网络
gas: 3012388,
gasPrice: 2000000000 //根据网络行情设定燃料价格
}
},
mocha: {},
compilers: {
solc: {
version: "0.8.17"
}
}
};
这个文件是项目的一些配置信息,MnemonicPhrase
为MetaMask钱包助记词(填写你自己的,12个单词用半角空格分隔),钱包中的地址为合约的发布者地址,所以这个地址要保证有余额;ProviderUrl
为网络接口地址;gas为最大使用燃气量,如果不够会报错,如果超出会退回;gasPrice为燃气价格,每个网络不同的,可以使用postman等工具查询各网络提供的JSON-RPC接口获取,如下图:
我这里也是用了一个chrome的插件来查询的,返回的结果是十六制的。可以百度一下在线转换网站或科学计算转换一下。你需要把燃料价格设得比当前价格高一点才能优先被执行,如果设置的低于当前价格,部署时会报错。
3.4 部署合约
保存上面的代码后,在资源管理器中鼠标右击合约文件(如下图),在弹出菜单的最下面有Build Contracts
和Deploy Contracts
两个菜单,Build Contracts
为执行编译合约命令,Deploy Contracts
为部署合约命令。因为执行部署命令时会先编译,所以可以直接点击Deploy Contracts
菜单。
然后在弹框中选择刚才在truffle-config.js配置文件中配置的sepoliaTestNet网络开始部署,如下图:
有时右下角会提示再次提示安装@truffle/hdwallet-provider钱包,点击“安装”即可。如果部署不成功,再次重复上面的操作来部署即可。
出现类似下面的结果即为部署成功,如果出现其他错误提示,按提示内容来处理。
777_deploy.js
=============
[Truffle: Execute command]
Deploying 'Elwin777'
--------------------
[Truffle: Execute command] > transaction hash: 0x0c29f0d31160c280fe063f5ffdf6242f6a487149058b201dc422fc3a669bb3df
[Truffle: Execute command] - Blocks: 0 Seconds: 0
[Truffle: Execute command] - Blocks: 1 Seconds: 5
[Truffle: Execute command] - Blocks: 1 Seconds: 9
[Truffle: Execute command] - Blocks: 2 Seconds: 13
[Truffle: Execute command] > Blocks: 2 Seconds: 13
> contract address: 0xD1687a78902d2894647f393f12ceA83A89499F0e
> block number: 2354753
> block timestamp: 1669363932
> account: 0x310cEC42257cdD929D3fe1b72CC6f1e0B333D3CD
> balance: 2.112295162499165901
> gas used: 2629372 (0x281efc)
> gas price: 2 gwei
> value sent: 0 ETH
> total cost: 0.005258744 ETH
[Truffle: Execute command] > Saving artifacts
-------------------------------------
> Total cost: 0.005258744 ETH
Summary
=======
> Total deployments: 1
> Final cost: 0.005258744 ETH
[Truffle: Execute command]
[Truffle: Execute command] Finished running command
[Truffle for VSCode] Deploy succeeded
0xD1687a78902d2894647f393f12ceA83A89499F0e
为成功部署的合约地址,可以去https://sepolia.otterscan.io/查询一下。0x310cEC42257cdD929D3fe1b72CC6f1e0B333D3CD
为钱包账户地址,你会发现余额减少了,上面用了2629372个燃气,花费0.005258744个测试币。
发行一个ERC777以太坊代币这样就完成了,其实也不难的。同理,通过openzeppelin类库发一个NFT数字藏品也不难的,自己可以尝试下。
四、钱包中查看和管理代币
打开MetaMask钱包,点击最下面的“添加资产”链接,弹出如下界面:
输入代币合约地址,再点击下一个输入框,发现自动识别了代币符号和小数(小数位在ERC777标准中是18,不建议修改,即一个币可以拆分为更小的单位来交易,最多精确到小数点后18位),然后点击“添加自定义代币”按钮,然后再次确认点击“添加代币”按钮,就可以看到刚发行的代币了,如下图。
然后你还可以点击“发送”按钮,把代币发送给其他钱包地址。
五、代币验证
我们部署的合约,其实是部署了编译后的字节码;为了让你的合约更可信,可以上传合约源代码到etherscan.io网验证一下,这样显得你的代币合约更可信。
验证成功之后,etherscan.io网上查看合约地址时,可以看到合约的页签后面是有绿色的图标,点击可以看到合约的源码。
注意:etherscan.io这个网站目前国内是打不开的,所以我就不多介绍了。可以参考这篇文章:https://learnblockchain.cn/article/1314
感谢阅读,原创内容,转载请注明出处。