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 小米 华为 单反 装机 图拉丁
 
   -> 区块链 -> web3.js监听链上事件并记录在数据库 -> 正文阅读

[区块链]web3.js监听链上事件并记录在数据库

使用truffle新建个项目

truffle使用参考
truffle文档
文件目录如下:

contracts/: Solidity合约目录

migrations/: 部署脚本文件目录

test/: 测试脚本目录,参考 如何测试合约于应用?

truffle-config.js: Truffle 配置文件

写个简单的合约,并且部署到本地。
本地的节点是利用ganache-cli。

在src文件写监听事件的代码

mysql,node已经准备好。

db.js

// 配置链接数据库参数
module.exports = {
    host: 'localhost',
    port: 3306, // 端口号
    database: 'test', // 数据库名
    user: 'root', // 数据库用户名
    password: '' // 数据库密码
}

dbhelper.js

const mysql = require('mysql'); // 引入mysql模块
const databaseConfig = require('./db'); // 引入数据库配置模块中的数据

// 向外暴露方法
module.exports = {
    query: function(sql, params, callback) {
        // 每次使用的时候需要创建链接,数据操作完成之后要关闭连接
        let connection = mysql.createConnection(databaseConfig);
        connection.connect(function(err) {
            if(err) {
                console.log('数据库链接失败');
                throw err;
            }
            // 开始数据操作
            // 传入三个参数,第一个参数sql语句,第二个参数sql语句中需要的数据,第三个参数回调函数
            connection.query(sql, params, function(err, results, fields) {
                if(err) {
                    console.log('数据操作失败');
                    throw err;
                }
                // 将查询出来的数据返回给回调函数
                callback && callback(results, fields);
                // results作为数据操作后的结果,fields作为数据库连接的一些字段
                // 停止链接数据库,必须再查询语句后,要不然一调用这个方法,就直接停止链接,数据操作就会失败
                connection.end(function(err) {
                    if(err) {
                        console.log('关闭数据库连接失败!');
                        throw err;
                    }
                });
            });
        });
    }
};

index.js

const Web3=require('web3');
const MyContract=require('../build/contracts/Mycontract.json');
const db=require("./dbhelper")

const init =async()=>{
    const web3=new Web3('http://localhost:9545');
    const id =await web3.eth.net.getId();
    const deployedNetwork=MyContract.networks[id];
    const contract =new web3.eth.Contract(
        MyContract.abi,
        deployedNetwork.address
    );
    console.log("yuyu");
    //return
    
    
const address=await web3.eth.getAccounts();
    const receipt =await contract.methods
        .emitEvent('hey')
        .send({
            from: address[0]
    });

    console.log(receipt.events);
    console.log(receipt.events.MyEvent.returnValues.id );

    //保存事件
    var addSql = 'INSERT INTO blockevent(nextid,transactionIndex,transactionHash,blockHash,blockNumber,address,event,signature) VALUES(?,?,?,?,?,?,?,?)';
    var addSql2 = 'INSERT INTO define_value(id,date,value,event) VALUES(?,?,?,?)';
    var addSqlParams = [receipt.events.MyEvent.returnValues.eventId
        ,receipt.events.MyEvent.transactionIndex
        ,receipt.events.MyEvent.transactionHash
        ,receipt.events.MyEvent.blockHash
        ,receipt.events.MyEvent.blockNumber
        ,receipt.events.MyEvent.address
        ,receipt.events.MyEvent.event
        ,receipt.events.MyEvent.signature];
    var addSqlParams2 = [receipt.events.MyEvent.returnValues.eventId
        ,receipt.events.MyEvent.returnValues.date
        ,receipt.events.MyEvent.returnValues.value
        ,receipt.events.MyEvent.event];
    db.query(addSql, addSqlParams, function(err, result) {
        if(err){
            console.log('[INSERT ERROR] - ',err.message);
            return;
           }        
          console.log("insert success");        
 
    })
    db.query(addSql2, addSqlParams2, function(err, result) {
        if(err){
            console.log('[INSERT ERROR2] - ',err.message);
            return;
           }        
          console.log("insert2 success");        
 
    })
 
//the second one
    // await new Promise(resolve=>setTimeout(()=>resolve(),2000));

    // contract.events.MyEvent({}).on('data',event=>console.log(event));


// the third one
//    const results=await contract.getPastEvents(
//         'MyEvent',
//         {
//             NodeFilter :{
//                 value:'hey'
//             },
//             fromBloack: 0
//         }
//         );

    

}
init();

以上就菜鸟摸索区块链的一小步,继续加油。

  区块链 最新文章
盘点具备盈利潜力的几大加密板块,以及潜在
阅读笔记|让区块空间成为商品,打造Web3云
区块链1.0-比特币的数据结构
Team Finance被黑分析|黑客自建Token“瞒天
区块链≠绿色?波卡或成 Web3“生态环保”标
期货从入门到高深之手动交易系列D1课
以太坊基础---区块验证
进入以太坊合并的五个数字
经典同态加密算法Paillier解读 - 原理、实现
IPFS/Filecoin学习知识科普(四)
上一篇文章      下一篇文章      查看所有文章
加:2021-11-27 09:56:48  更:2021-11-27 09:57:13 
 
开发: 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年11日历 -2024/11/25 22:37:25-

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