zoukankan      html  css  js  c++  java
  • 三、部署智能合约到conflux公链

    一、准备合约

    本节课程教大家如何讲智能合约部署到conflux公链上,首先大家可以看到下面的这个智能合约是不是很简单。我们将会以这个合约演示部署到conflux公链的过程。

    pragma solidity ^0.5.0;
    
    contract Counter {
        uint public count=0;
        event SelfEvent(address indexed sender, uint current);
    
        constructor() public {
        }
    
        function inc(uint num) public returns (uint){
            return count += num;
        }
    
        function self() public {
            emit SelfEvent(msg.sender, count);
        }
    }
    复制代码

    二、conflux的sdk安装

    我们使用js-conflux-sdk作为本教程的web教程,交互首先我们需要进行安装nodejs作为我们的运行环境。飞机票一张收下吧,我们安装好nodejs后,就可以来玩我们的sdk了。废话不多说,直接开始撸。

    我们使用WIN + R键打开命令行,然后创建一个文件夹(温馨提示切换到非系统盘玩切换方式“D:”就切换到D盘了)使用“mkdir my-project && cd my-project” 创建好项目后自动进入文件夹,然后我们运行“npm init” 进行初始化node项目,这一步会让你确认一些东西,如果你是小白一路回车(Enter键)就好。如果你是前端大神,我也没啥好教的我也不太懂。为了稳定我们使用固定版本号方式安装依赖,我们运行 “npm install js-conflux-sdk@0.9.2” 命令进行安装js-conflux-sdk的0.9.2版本依赖(可以使用“npm uninstall package-name” 命令删除对应依赖)。前置准备到这里基本已经完成。

    三、编写调用合约js代码

    下面请看我的目录结构跟随我一起来学习,下面的目录结构请不要直接看到了就创建,因为你不知道都是什么意思,看玩我的解释在回头创建。

    image

    小伙伴应该已经发现了 node_modules、package-lock.json、package.json 这些文件是我们在进行安装 sdk依赖时自动生成的。其他文件目前都没有,我们来按顺序生成他们。

    先创建sol这个文件夹,然后创建这三个文件。test.sol就是上面我们的合约代码直接拷入文件中。abi.json和code.json两个文件是通过这个工具 remix 在线生成的。我来说下生成过程。 首先我们将里面的文件全部删除,然后点击这里找到我们的项目目录下的test.sol 文件

    我们应该看到下方我框出来的两个按钮了吧,那两个按钮就是abi.json和code.json文件的来源。abi.json我们可以直接复制过去,code.json文件我们要改点东西。

    首先我们看到的code文件应该是这样的

    {
    	"linkReferences": {},
    	"object": "608060405260...c63430005110032",
    	"opcodes": "PUSH1 0x80 PUSH1 ... 1100 ORIGIN ",
    	"sourceMap": "27:337:0 ... 37;;;;;;"
    }
    复制代码

    代码有省略,太长不好看,我们看到object这个key值了吧,我们把它的值考出来然后在头部加0x 就好了放在code.json文件中。code.js文件中只存放object的内容前面加0x,也就是下面的代码,其他信息都不要,千万记住了。这点很重要!!!!

    "0x608060405260...c63430005110032"
    复制代码

    就是这样的。然后我们在写另外两个call和deploy两个文件

    先写deploy文件

    
    // 私钥地址
    const PRIVATE_KEY = '0x20f9169d40801955faada641cdb029f8e42c581c0c991a62753c736a0a168e5e';
    // 合约地址
    const CONTRACT = '';
    const { Conflux } = require('js-conflux-sdk');
    
    async function main() {
      const cfx = new Conflux({
        url: 'http://mainnet-jsonrpc.conflux-chain.org:12537',
        defaultGasPrice: 100,
        defaultGas: 1000000,
      });
      const account = cfx.Account(PRIVATE_KEY); // create account instance
      console.log(account.address); 
    
      // create contract instance
      const contract = cfx.Contract({
        abi: require('./sol/RC20.abi.json'),
        bytecode: require('./sol/RC20.code.json'),
      });
    
      const receipt = await contract.constructor()
        .sendTransaction({ from: account })
        .confirmed();
      console.log(receipt.contractCreated); 
    }
    main().catch(e => console.error(e));
    复制代码

    打开项目cmd窗口在上面的目录下 运行命令 “node deploy.js”就将合约部署上去了

    receipt.contractCreated 这个会打印出合约地址。


    作者:悠悠_15832013094
    链接:https://juejin.im/post/5ef563f75188252e99702335
    来源:掘金
    著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
  • 相关阅读:

    HttpClient发送get/post请求
    maven创建ssm项目依赖(pom.xml文件)
    java的Scanner类总结
    java多线程总结
    java跨域问题
    Idea打包项目war并且发布到服务器
    Mybatis入门案例之增删改查
    springMVC中的@RequestBody和@ResponseBody以及@RequestParam
    Gson解析json
  • 原文地址:https://www.cnblogs.com/youyou158/p/13258159.html
Copyright © 2011-2022 走看看