IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 区块链 -> 01 DAPP简单Demo -> 正文阅读

[区块链]01 DAPP简单Demo

参考:
https://www.jianshu.com/p/683ea7d62a39
令狐一冲: https://www.bilibili.com/video/BV14z4y1Z7Jd?

一、公共环境搭建

1.1 Ubuntu20.04 虚拟机环境

https://zhuanlan.zhihu.com/p/141033713

1.2 Git安装

sudo add-apt-repository ppa:git-core/ppa
sudo apt-get update
sudo apt install git
git --version

二、开发方法一:geth+js

2.1 Geth安装

sudo apt-get install software-properties-common
sudo add-apt-repository -y ppa:ethereum/ethereum
sudo add-apt-repository -y ppa:ethereum/ethereum-dev
sudo apt-get update
sudo apt-get install ethereum
geth help		//查看是否安装成功

在这里插入图片描述

2.2 创始区块json

cd ~/private_geth
vim genesis.json
{
    "nonce": "0x0000000000000042",
    "difficulty": "0x200",
    "mixhash": "0x0000000000000000000000000000000000000000000000000000000000000000",
    "coinbase":"0x0000000000000000000000000000000000000000",
    "timestamp": "0x0",
    "parentHash": "0x0000000000000000000000000000000000000000000000000000000000000000",
    "extraData":"0x",
    "gasLimit": "0x8000000",
    "alloc": {},
    "config": {
        "chainId": 6500,
        "homesteadBlock": 0,
    }
}

字段含义
alloc可以预置账号以及账号的以太币数量
coinbase区块受益者地址,可以设置为已经存在的账户,后面挖出的区块的受益者监视挖出那个区块的账户(矿工)
difficulty代表当前区块难度等级,这里定义创始区块的难度等级,难度等级越高,挖矿越难,后面生成的区块难度等级根据前一个区块的难度等级和时间戳计算得到
extraData一个包含这个区块相关数据的字节数组,任意填写,必须在32位以内
gasLimit执行这个事务应该被使用gas的最大值,这个在任何计算被做之前是预付的,并且在这个之后不会增加
nonce代表从这个地址发送的事务的数目,或者在关联代码的账户下,则代表这个账户创造的合约数目
mixhash由nonce合并,怎么在这个区块上已经执行足够量的计算
parentHash上一个区块的header的keccak256算法hash
timestamp这个区块开始的Unix time()和合理输出

2.3 初始化geth

指定生成在chain目录下

geth --datadir "chain" init genesis.json

在这里插入图片描述

2.4 启动geth节点

geth --identity "myetherum"   --datadir "chain" --http --http.api db,eth,net,web3,personal,miner --networkid 6500 console 2>>chain/geth.log

注意这里的networkid就是genesis.json中的chainId
在这里插入图片描述
tips:关于–rpc启动失效:https://blog.csdn.net/claysystem/article/details/121133081

2.5 创建账户

personal.newAccount("jessy")

查看账户

 eth.accounts

2.6 挖矿,需要耐心等待一会

开始挖矿

miner.start()

查看挖矿状态

eth.mining

关闭挖矿

miner.stop()

在这里插入图片描述

三、开发方法二:Ganache+js

由开发方法一中可以看到挖矿速度实在感人,所以可以使用ganache在内存中模拟区块链,注意在开发时,geth+js(搭建一个私链)和ganache+js(模拟区块链)两个方法选一个就行

ganache是truffle框架中的一个组件,个人区块链2333,ganache也就是之前的testrpc

ganache 要求npm>=v8
在这里插入图片描述

3.1 安装Node

https://blog.csdn.net/huiskai/article/details/116109255

wget https://npmmirror.com/mirrors/node/v16.14.2/node-v16.14.2-linux-x64.tar.xz
 tar -xvf node-v16.14.2-linux-x64.tar.xz
mv node-v16.14.2-linux-x64 /usr/local/node

建立软链接

//切换目录
cd /usr/bin
//创建node软链接
sudo ln -s /usr/local/node/bin/node node
//创建npm软链接
sudo ln -s /usr/local/node/bin/npm npm

查看是否安装成功
在这里插入图片描述

3.2 安装genache-cli

npm install -g ganache-cli

然后设置全局变量

vim ~/.bashrc

在最末尾添加存放node的路径

export PATH="/usr/local/node/bin/:$PATH"

然后使其生效

source ~/.bashrc

即可查看是否安装成功

ganache-cli

可以看到自己生成了10个账户,每个账户中有100ETH
在这里插入图片描述
ctrl+C关闭ganache

3.3 安装Web3.js与以太坊交互

新建一个文件夹安装web3

cd ~
mkdir GanacheLearn
cd GanacheLearn
sudo npm install web3 -save

写一个测试文件测试

vim test.js
var Web3 = require('web3');
var web3 = new Web3(new Web3.providers.HttpProvider('http://localhost:8545'));
console.log(web3.version);	//版本号无论是否运行Ganache都可以访问
web3.eth.getAccounts().then(console.log);       //打印账户                                  

在不允许ganache的时候是不能获取到账户的

在这里插入图片描述
另起终端运行ganache

在这里插入图片描述
然后再运行test.js,发现可以获取到信息了,这就是web3.js和以太坊网络进行交互

在这里插入图片描述

四、简单的Dapp开发Demo

tips:

  1. 要使用官方文档时注意查对应的版本号
  2. geth和ganache的端口都一样8545

1、新建工程目录
2、新建express项目

express -e dapp

在这里插入图片描述
3、安装

npm install

在这里插入图片描述
4、启动测试
在这里插入图片描述
在这里插入图片描述
4、本项目安装web3

npm install web3 -save

5、修改express项目中的app.js

var ejs=require('ejs');

app.engine('.html',ejs.__express);
app.set('view engine', 'html');
//app.set('view engine', 'ejs');

在这里插入图片描述

5、修改router目录下的index.js

var Web3 = require('web3');
var web3 = new Web3(new Web3.providers.HttpProvider('http://localhost:8545'));
web3.eth.getAccounts().then(console.log);

在这里插入图片描述
6、将views目录下的index.ejs内容拷贝到index.html(自己新建)
在这里插入图片描述
7、部署一个简单合约到ganache中

remix中编写一个简单的计数器counter合约
https://remix.ethereum.org

pragma solidity >=0.4.22 <0.8.0;

contract MyCounter{
    uint256 counter;

    constructor() public{
        counter =1;
    }

    function kipCounter(uint step)public{
        counter +=step;
    }

    function getCounter() public view returns(uint256){
        return counter;
    }
}

然后编译之后,查看字节码
在这里插入图片描述
在这里插入图片描述
在项目中新建一个文件夹deploy,在下面写一个deploy.js用于部署合约:

  • 首先编写建立连接的代码
var Web3 = require('web3');
var web3 = new Web3(new Web3.providers.HttpProvider('http://localhost:8545'));

//web3.eth.getAccounts().then(console.log);
  • 然后拷贝remix中自动生成的代码
    在这里插入图片描述

  • 再添加字节码和修改账户(使用ganache-cli生成账户的第一个账户)
    在这里插入图片描述
    在这里插入图片描述

  • 最后添加回调,查看合约部署的地址
    在这里插入图片描述
    运行

node deploy.js

在这里插入图片描述

8、dapp调用合约函数
(1)在index.js中,创建合约对象,第一个参数是编译后产生的ABI,第二个参数是合约地址
在这里插入图片描述
在这里插入图片描述
(2)调用合约函数
调用不需要修改合约的方式用call

//需要传部署合约的地址
myContract.methods.getCounter().call({from:'0x1AE6d878097c2f4E183dAbd0D5EA4661Ad5Ee154'},function(error,result){console.log("counter:",result);});

//不需要传部署合约的地址
myContract.methods.getCounter().call().then(function(counter){
  console.log('init counter:',counter);
  init_counter=counter;
});

在这里插入图片描述
在这里插入图片描述
(3)调用需要修改合约的函数

myContract.methods.kipCounter(5).send({from:'0x1AE6d878097c2f4E183dAbd0D5EA4661Ad5Ee154'}).then(function(){
    myContract.methods.getCounter().call().then(function(counter){
      console.log('init counter:',counter);
      current_counter=counter;
      res.render('index', { init: init_counter ,current:current_counter});
    });
  })

在这里插入图片描述
(4)修改index.html

<!DOCTYPE html>
<html>
  <head>
    <title>调用智能合约</title>
    <link rel='stylesheet' href='/stylesheets/style.css' />
  </head>
  <body>
    <h1>init: <%= init %></h1>
    <p>current: <%= current %></p>
  </body>
</html>

运行结果:
在这里插入图片描述

  区块链 最新文章
盘点具备盈利潜力的几大加密板块,以及潜在
阅读笔记|让区块空间成为商品,打造Web3云
区块链1.0-比特币的数据结构
Team Finance被黑分析|黑客自建Token“瞒天
区块链≠绿色?波卡或成 Web3“生态环保”标
期货从入门到高深之手动交易系列D1课
以太坊基础---区块验证
进入以太坊合并的五个数字
经典同态加密算法Paillier解读 - 原理、实现
IPFS/Filecoin学习知识科普(四)
上一篇文章      下一篇文章      查看所有文章
加:2022-04-01 00:08:05  更:2022-04-01 00:08:19 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年12日历 -2024/12/28 19:43:00-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码
数据统计