【区块链】利用Node.js开发与合约交互的Web界面

本文介绍了如何使用Node.js和web3.js库开发一个与智能合约交互的Web界面。首先,在私有链上部署合约,然后新建Node.js项目并导入web3.js。接着,创建web3对象并与合约进行交互,包括部署、调用合约以及创建账户。最后,通过集成Express实现Web界面,利用BigNumber.js处理大数字,并提供了app.js、html及main.js的代码示例。
摘要由CSDN通过智能技术生成

利用Node.js开发与合约交互的Web界面

参考地址:here and here

零、在私有链上部署合约

// 本文中用到的MetaCoin合约
pragma solidity ^0.4.2;

contract MetaCoin {
    mapping (address => uint) balances;

    event Transfer(address indexed _from, address indexed _to, uint256 _value);

    function MetaCoin() {
   
        balances[tx.origin] = 10000;
    }

    function sendCoin(address receiver, uint amount) returns(bool sufficient) {
   
        if (balances[msg.sender] < amount) return false;
        balances[msg.sender] -= amount;
        balances[receiver] += amount;
        Transfer(msg.sender, receiver, amount);
        return true;
    }

    function getBalance(address addr) returns(uint) {
   
        return balances[addr];
    }
}

一、新建一个项目

新建一个node.js项目并初始化

$ mkdir web3test && cd web3test
$ npm init

二、导入web3.js

npm install web3 --save

三、创建web3对象

var Web3 = require("web3");
//创建web3对象
var web3 = new Web3();
// 连接到以太坊节点
web3.setProvider(new Web3.providers.HttpProvider("http://localhost:8545"));

可以测试一下:

var version = web3.version.node;
console.log(version);
==>
在app目录下,终端输入:
prodeMacBook-Pro:web3test pro$ node app.js
输出:
Geth/linoy/v1.6.5-stable-cf87713d/darwin-amd64/go1.8.3

四、调用合约

部署合约:
私有链上查看地址,abi可以通过here获取

var abi = [{
  "constant":false,"inputs":[{
  "name":"receiver","type":"address"},{
  "name":"amount","type":"uint256"}],"name":"sendCoin","outputs":[{
  "name":"sufficient","type":"bool"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{
  "constant":false,"inputs":[{
  "name":"addr","type":"address"}],"name":"getBalance","outputs":[{
  "name":"","type":"uint256"}],"payable":false,"stateMutability":"nonpayable","type":"function"},{
  "inputs":[],"payable":false,"stateMutability":"nonpayable","type":"constructor"},{
  "anonymous":
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值