美文网首页
以太坊ERC777标准代币(token)发行实战

以太坊ERC777标准代币(token)发行实战

作者: 木巽 | 来源:发表于2022-11-28 10:13 被阅读0次

    一、前期准备

    首先了解下EIP777提案的内容:https://learnblockchain.cn/docs/eips/eip-777.html,它解决了ERC20标准存在的一些问题,同时也是完全兼容ERC20标准的,在钱包中和ERC20合约代币一样使用。现在学,当然要用最新的标准了。话说为什么要用这些标准呢,因为自己随便写的程序,第三方钱包软件是无法识别,所以就要通过实现官方标准接口来开发。

    发布智能合约(开发的程序)是需要交易费的,所以我们一般在测试链进行。以太坊今年升级到2.0后,有些测试网络就不推荐使用了,目前只推荐goerlisepolia这两个测试网。当然你也可以去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插件,然后再点击“安装”按钮即可。我已经安装了,所以显示的是“卸载”按钮。

    Truffle 插件安装
    当然你也可以用官方的remix在线开发工具:https://remix.ethereum.org/,我用起来感觉不是很方便。

    2.2 安装MetaMask钱包

    因为发布智能合约(代币程序)需要交易费的,所以就需要用到钱包和测试币。MetaMask轻钱包就很适合,它以浏览器插件的形式运行,主流浏览器都支持,看你喜欢下载哪一个https://metamask.io/download/ ,我用的是chrome插件。具体安装过程不介绍了,网上很多教程。如果第一次创建钱包账户的话,会生成12个助记单词,你要把这些记下来(顺序不能错)并妥善保管,后面要用到。助记词或私钥就相当于你的银行卡密码,一旦泄露别人就能转走你的虚拟资产,如果只有测试币那倒没关系。

    Metamask打开测试网络
    点击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”创建一个空的项目,会弹出对话框选择一个目录来存储代码。


    vscode中新建Truffle项目

    3.2 安装类库

    项目创建完成之后,再点击菜单“查看”-“终端”,打开终端面板(如下图1)。当然你也可以在windows运行cmd“命令提示符”或“终端”程序,切换到项目目录下,执行下面的命令:

    # 设置国内镜像,提高下载速度
    npm config set registry https://registry.npm.taobao.org 
    npm i @openzeppelin/contracts
    npm i @truffle/hdwallet-provider
    

    第一个npm config命令是配置下载镜像,提高下载速度,如果已经执行过可以忽略。

    @openzeppelin/contracts是开源的solidity代币或NFT代码库,官方的文档:https://docs.openzeppelin.com/contracts/4.x/erc777
    node_modules\@openzeppelin\contracts\token\ERC777 目录下,可以看到等下要用到的代码。

    @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/ERC777/ERC777.sol";
    
    contract Elwin777 is ERC777 {
        constructor(uint256 initialSupply, address[] memory defaultOperators)
            ERC777("Elwin777", "EZ7", defaultOperators)
        {
            _mint(msg.sender, initialSupply * (10 ** decimals()), "", "");
        }
    }
    

    只有几行代码,之前学solidity语言用了很久,现在觉得有点浪费时间了。合约名称也是Elwin777和文件名保持一致。导入了openzeppelin/contracts类库中的ERC777.sol文件,并继承了这个合约。

    合约只有一个构造函数,initialSupply参数是初始发行代币数量;defaultOperators参数是一个地址数组表示这个代币合约的默认管理员有哪些,可以不传。其中ERC777("Elwin777", "EZ7", defaultOperators)这一行调用父合约中的构造函数,第一个参数为代币名称,第二参数是代币的符号(缩写),这两个参数很重要,自己修改成你喜欢的名称。

    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 ContractsDeploy 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

    感谢阅读,原创内容,转载请注明出处。

    相关文章

      网友评论

          本文标题:以太坊ERC777标准代币(token)发行实战

          本文链接:https://www.haomeiwen.com/subject/uvylfdtx.html