nodejs部署智能合约的方法-web3 0.20版本

参考:https://www.jianshu.com/p/7e541cd67be2

部署智能合约的方法有很多,比如使用truffle框架,使用remix-ide等,在这里的部署方法是使用nodejs一步步编译部署实现的:

const Web3 = require(‘web3‘);
const web3 = new Web3();//使用web3来进行区块链接口的调用

//通过rpc连接区块链,这里连接的是本地私有链
web3.setProvider(new Web3.providers.HttpProvider(‘http://127.0.0.1:7545‘));
const fs = require("fs");
const solc = require("solc");
let source = fs.readFileSync(“token.sol",‘utf8‘);//读取sol智能合约文件
//对智能合约进行编译,第二个参数设置为1可以激活优化器optimiser
let compiledContract = solc.compile(source,1);

for (let contractName in compiledContract.contracts) {
    var bytecode = compiledContract.contracts[contractName].bytecode;//获得编译后合约的bytecode
    var abi = JSON.parse(compiledContract.contracts[contractName].interface); //获得编译后合约的abi并写成json形式
}

let gasEstimate = web3.eth.estimateGas({data:’0x’+bytecode});//获得这个合约部署大概所需的gas
let MyContract = web3.eth.contract(abi);

//上面是编译生成了Abi的方法,之后就有两种进行使用的情况:
(1)
//当从来没有部署过时,这里的gas例子上是gas:gasEstimate,但是我发现有些时候好像过小而不能成功,所以我每次为了保证能够绝对地成功,都设为一个很大的数,反正用不完会返回来的,你也可以设置为gas:gasEstimate,但是如果后面有发现有错误,很有可能是这里的问题

    var instance = MyContract.new(50,{from:user1,data:‘0x‘+bytecode,gas:47000000},function(e,contract){
             if(typeof contract.address !== ‘undefined‘){
                console.log(‘Contract mined! address: ‘ + contract.address + ‘ transactionHash: ‘ + contract.transactionHash);
            }
    });

然后后面就可以使用instance来调用智能合约中的函数等信息了

(2)

//当已经在私有链上部署过时,里面的地址即为上面的方法得到的contract.address

let instance = MyContract.at(‘0x86757c9bdea10815e7d75a1577b6d9d2825dae0a‘);//可改

不过这种方式有一个问题,就是在发布合约时,你的私钥处于联网状态,

处于安全策略,我们需要尽量避免私钥在联网状态。

以太坊上部署合约是向空地址发送一个附有字节码的签名交易,其中发送者就是这个合约的拥有者。

因此我们只需要将合约构建成一笔交易,我们在无网状态下对这笔交易进行签名,然后将签名发送到以太坊网络中。这样能够降低我们私钥被泄漏的风险。
在这里要使用方法进行合约部署,参考:https://my.oschina.net/u/3794778/blog/1801897

web3.eth.sendRawTransaction(signedTransactionData [, callback])

参数:

    signedTransacionData: String - 16进制格式的签名交易数据。
    callback: Function - 回调函数,用于支持异步的方式执行7。

返回值:

    String - 32字节的16进制格式的交易哈希串。

示例:
var Tx = require(‘ethereumjs-tx‘);//ethereumjs-tx 提供了私钥到公钥的转换方法//你自己的私钥
var privateKey = new Buffer(‘e331b6d69882b4cb4ea581d88e0b604039a3de5967688d3dcffdd2270c0fd109‘, ‘hex‘);
//构造的交易中,是不需要包含 from 的,因为这个交易是通过私钥签名的,而私钥生成的签名是可以还原出公钥地址的,所以交易本身不需要冗余存储发送方信息。
var rawTx = {  //这个字段需要取你的发送账号所发起的交易的计数器,可以通过 eth_getTransactionCount 来获取当前的 nonce,直接用,不用加1
  nonce: ‘0x00‘,
  gasPrice: ‘0x09184e72a000‘,
  gasLimit: ‘0x2710‘,
  to: ‘0x0000000000000000000000000000000000000000‘, //to到空地址
  value: ‘0x00‘, //可以省略
  data: ‘0x7f7465737432000000000000000000000000000000000000000000000000000000600057‘//就是之前生成的‘0x‘+bytecode
}

var tx = new Tx(rawTx);
tx.sign(privateKey);

var serializedTx = tx.serialize();
 //这里得到的值就是需要的16进制格式的签名交易数据
//console.log(serializedTx.toString(‘hex‘));
//0xf889808609184e72a00082271094000000000000000000000000000000000000000080a47f74657374320000000000000000000000000000000000000000000000000000006000571ca08a8bbf888cfa37bbf0bb965423625641fc956967b81d12e23709cead01446075a01ce999b56a8a88504be365442ea61239198e23d1fce7d00fcfc5cd3b44b7215f

web3.eth.sendRawTransaction(serializedTx.toString(‘hex‘), function(err, hash) {
  if (!err)
    console.log(hash); // "0x7f9fade1c0d57a7af66ab4ead79fade1c0d57a7af66ab4ead7c2c2eb7b11a91385"这里得到的就是交易成功返回的交易hash
});

最后,生成的字节码可以直接到第三方,比如 https://etherscan.io/pushTx 来广播你的交易,如果广播失败,可以直接看到错误提示信息

下面这个网址是对etherscan这个工具的解释解释得很好,可以看看
http://8btc.com/thread-75748-1-7.html

原文地址:https://www.cnblogs.com/wanghui-garcia/p/9505886.html

时间: 2024-10-01 06:23:22

nodejs部署智能合约的方法-web3 0.20版本的相关文章

十分钟部署智能合约

eos环境搭建 1.git clone源代码 git clonehttps://github.com/EOSIO/eos --recursive 2.下载编译之后,里面有三个应用程序,这三个应用程序也都是命令行的: 1.Cleos: 2.Nodeos: 3.Keosd. 这三个应用程序之间有什么关系呢?我们现在使用的前端,怎么使用EOS呢? -Cleos,它是一个命令行程序.在前端使用EOS是通过Cleos输入命令,给EOS下达指令. -Nodeos,其实它就是挖矿客户端.在启动Nodeos之后

fabric 环境搭建 和 部署 智能合约 - (实习第二天)

首先安装docker,安装的时候有坑,坑就是资料没找对. 这篇博客的意义就是没有坑安装好,部署好. 我用的是 Ubuntu 18.04 安装Docker-ce,这下面的安装方式就是菜鸟教程的,可以去哪看. 1.更换国内软件源,推荐中国科技大学的源,稳定速度快(可选) sudo cp /etc/apt/sources.list /etc/apt/sources.list.bak sudo sed -i 's/archive.ubuntu.com/mirrors.ustc.edu.cn/g' /et

区块链入门(5)Truffle 项目实战,Solidity IDE, 智能合约部署

在上一张我们学习了Truffle项目的创建,部署等相关内容,今天我们就来实战一下. 今天我们要做3件事: 1) 学习搭建一个Solidity IDE(Remix). 2) 使用这个Solidity Ide编写一份智能合约. 3) 在我们前面第1,2,3章中部署的私有网络节点集群中部署这个合约,并能够在不同的节点中调用这个合约. Remix,是一个Solidity开发语言的Ide, 它是一款运行在浏览器端的solidity ide,也是官方推荐使用的ide. 另外还有其它的solidiy ide,

使用 Browser-solidity 在 Go-Ethereum 上进行简单的智能合约部署

1.基本概念 之前文章中,已经讲过 Go-Ethereum 1.7.2 如何安装及搭建以太坊私有链,这里就不多介绍. 在本文讲解之前,先介绍以下几点基本概念. 1.1.什么是智能合约? 智能合约是存储在区块链上的一段代码,它们可以被区块链上的交易所触发,触发后,这段代码可以从区块链上读取数据或者向区块链上写入数据. 1.2.什么是Solidity? Solidity 是 Ethereum 的一种契约型编程语言,运行在Ethereum虚拟机(EVM)之上. 1.2.1.Solidity的语言特性

第一行代码:以太坊(3)-使用更多的工具编写和测试智能合约

<第一行代码:以太坊>开始连载了 在上文中已经使用了Remix环境运行和测试了本书编写的第一个智能合约程序,不过编写和测试智能合约的测试方式很多,例如,在testrpc环境测试:在Intellij IDEA集成开发环境中用Solidity语言编写智能合约:在纯Web环境中测试智能合约:使用AJAX方式测试智能合约等.本文将详细介绍这些用于编写和测试智能合约的方法. 1.安装本地remix环境(Windows.Mac OS X和Linux) 在本节使用Remix环境运行和测试了Calc智能合约,

【刘文彬】【精解】开发一个智能合约

原文链接:醒者呆的博客园,https://www.cnblogs.com/Evsward/p/contract.html 智能合约 这两天被老大搞去搬砖,学习计划有变但无大碍,这篇文章将仔细分析智能合约相关内容. 关键字:智能合约,remix,Solidity,truffle,geth,leveldb,datadir,ganache,web3j 合约 合约也称合同.协议,是甲乙双方参与的,制定一系列条目规范双方权利与义务的文件.智能合约是电子化的,自动执行的,去中心化的,具有不可抵赖性,本质上它

web3j开发以太坊智能合约快速入门(特别适合java和android开发者)

web3j简介 web3j是一个轻量级.高度模块化.响应式.类型安全的Java和Android类库提供丰富API,用于处理以太坊智能合约及与以太坊网络上的客户端(节点)进行集成. 可以通过它进行以太坊区块链的开发,而无需为你的应用平台编写集成代码. 可以快速启动dmeo示例 想要快速启动的话,有一个Web3j demo示例项目可用,演示了通过Web3j开发以太坊的许多核心特征,其中包括: 连接到以太网网络上的节点 加载一个以太坊钱包文件 将以太币从一个地址发送到另一个地址 向网络部署智能合约 从

如何用python和flask以太坊智能合约开发

将数据存储在数据库中是任何软件应用程序不可或缺的一部分.无论如何控制该数据库都有一个该数据的主控.区块链技术将数据存储到区块链网络内的区块中.因此,只要某个节点与网络同步,它们就会获得区块中数据的副本.因此,该技术中没有特定的数据主控. 在本教程中,我们将编写一份智能合约(我将进一步解释),以便在区块链上保留用户数据.我们将使用python web3(web3的python库)来开发和部署智能合约.一旦我们在区块链上部署了智能合约.我们将使用flask API与智能合约进行交互以存储一些数据/信

Windows下以太坊集成开发环境(Remix-IDE)搭建与智能合约的简单应用

前面我们介绍了在以太坊平台下开发区块链私有链的过程,以及在私有链下进行挖矿的操作,而随着区块链技术的发展,区块链技术已不仅限于比特币的应用,未来将重在着眼于向其他领域的扩展推广,以此开启区块链2.0以智能合约为代表的时代.本文选用remix作为开发应用平台,配合geth客户端实现与以太坊网络的交互,下一篇文章则改用truffle和ganache搭建开发框架(这是后话). 本文分为remix-ide搭建和智能合约部署应用两部分. 一.remix-ide搭建 [准备工作] 1.安装Node.js.N