以太坊概论考察课
更具课堂教学讲解,参考开放资料。使用所学的知识,创建项目并完成要求的内容。包含的功能和要求具体如下:
一:安装并运行geth客户端
1、下载安装geth
首先下载geth:https://geth.ethereum.org/downloads/
选择路径↓
2、配置环境变量
3、运行geth如下命令所示:
查看geth命令。使用geth version查看geth 版本号,判断geth是否成功安装。如下命令所示:
`geth version`
可以通过geth --help查看geth工具所支持的命令和相关参数,方便后期关于geth的操作。
如下命令所示:
geth --help
运行结果如下:
二:搭建geth联盟链网络,并实现多节点间的通信
1、初始化创世区块
在geth的根目录下添加genesis.json文件,genesis.json中代码如下
{
"alloc": {
"0x63b47f8abf5d47c9a90bab0ce0c6222b6cb2808a": { //使用账户1创建
"balance": "999000000000000000000"
}
},
"config":{
"chainId":10,
"homesteadBlock":0,
"eip155Block":0,
"eip158Block":0
},
"nonce":"0x0000000000000042",
"mixhash":"0x0000000000000000000000000000000000000000000000000000000000000000",
"difficulty": "0x2000",
"alloc": {},
"coinbase":"0x0000000000000000000000000000000000000000",
"timestamp": "0x00",
"parentHash":"0x0000000000000000000000000000000000000000000000000000000000000000",
"extraData": "",
"gasLimit":"0xffffffff"
}
使用geth --datadir chain1 init genesis.json
初始化创世区块
geth --datadir chain1 init genesis.json
在geth的安装目录下启动cmd,输入
geth --datadir chain1 --nodiscover console
进入geth控制台模式,其中chain1为帐户和区块数据目录
2、搭建联盟链,
win+R打开第二个控制台输入以下命令。 (初始化创世块的命令)
geth --datadir ./data-init2/ init genesis.json
启动并且进入控制台。(注意此处多一个ipcdiable参数,如与第一个控制台一样,会报错:Erro starting protocol stack:Access is denied)
分别在两个控制台创建新的账号,并记录地址
使用eth.accounts
命令查看现有帐户,当前是空
使用 personal.newAccount("root")
创建2个账户 //root为密码
账户1:0x134a886c1f30bd52febed873054de8b7ae7e92e5
账户2:0x751b26bf96544c6bc50c9290a0e64631f7a82ec1
使用eth.getBalance
()命令查看现有帐户,当前是空
1.查看节点的peers的情况。
admin.peers
通过分享enode地址的方式来让两个节点建立链接。
admin.nodeInfo.enode
复制节点2的enode的信息,在节点1的控制台执行以下命令。
admin.addPeer ("enode://0bd1b7da689dd574eae04d20484086a5c59d81981b927602ef745233a72eac3280ea1a193a41c24d05fae54ae9e78d4fd76b590ffc356c6786eb6f70b0e6b276@[::]:40404?discport=0")
在控制台1执行挖矿miner.start()
时,我们会发现节点2的控制台出现了这样的日志信息,则同步成功
查看coinbase地址金额发现有增长。
三:使用solidity编写智能合约程序,并部署在geth客户端
在remix中编译一个简单的智能合约
`pragma solidity ^0.4.18;`
`contract test{`
`function multiply(uint a)public view returns(uint d){`
`return a*7;`
`}`
`}
编译上述代码,在编译详情里可以看到字节码和ABI信息
{
--
"object": "608060405234801561001057600080fd5b5060bb8061001f6000396000f300608060405260043610603f576000357c0100000000000000000000000000000000000000000000000000000000900463ffffffff168063c6888fa1146044575b600080fd5b348015604f57600080fd5b50606c600480360381019080803590602001909291905050506082565b6040518082815260200191505060405180910390f35b60006007820290509190505600a165627a7a723058209135a65fdddd7be677810243db99bc4cbe46fcf74ee4ce1a3a8cc7fdbab004ef0029",
--
}
ABI文件
[
{
"constant": true,
"inputs": [
{
"name": "a",
"type": "uint256"
}
],
"name": "multiply",
"outputs": [
{
"name": "d",
"type": "uint256"
}
],
"payable": false,
"stateMutability": "view",
"type": "function"
}
]
通过ABI创建合约对象,而后在cmd中解锁我们之前创建的账户,并部署合约
contractInstance = myContract.new({data: bytecode,gas: 1000000, from: eth.coinbase}, function(e, contract){
if(!e){
if(!contract.address){
console.log("Contract transaction send: Transaction Hash: "+contract.transactionHash+" waiting to be mined...");
}else{
console.log("Contract mined! Address: "+contract.address);
console.log(contract);
}
}else{
console.log(e)
}
})
四:通过终端操作,完成合约功能调用(创建账户,并测试挖矿功能
使用第一步代码创建节点3,获取encode地址与节点2链接
解锁节点3
使用节点二对节点三进行转账操作
发送转账命令
eth.sendTransaction({from: "0x134a886c1f30bd52febed873054de8b7ae7e92e5", to: "0x0df12fd40b27405558103da6f6938eb8c257d", value: "74000000000000000"})
查询余额为
74
五:多节点之间完成交易的功能,并设置和估算gas用量
设置gas值
01337036)]
使用节点二对节点三进行转账操作
发送转账命令
eth.sendTransaction({from: "0x134a886c1f30bd52febed873054de8b7ae7e92e5", to: "0x0df12fd40b27405558103da6f6938eb8c257d", value: "74000000000000000"})
查询余额为
74