这篇文章将为大家详细讲解有关node.js中怎么实现一个Fabric链码,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。
fabric-shim是较底层的链码开发包,它封装了与节点通信的grpc协议。安装方法如下:
~/fabric-shim-chaincode-demo$ npm install fabric-shim
fabric-shim要求链码开发者定义一个实现两个预定义方法的类。
Init(stub):初始化链码时节点将调用该方法
Invoke(stub):节点将应用对链码的调用转化为对该方法的调用
参数stub
由节点传入,它提供了访问链上账本的方法,以便读取或更新账本状态。
例如,下面的代码实现了一个最小化的node.js链码,每次调用链码都会更新acc0的状态(例如:可以使用这个状态代表账户余额):
const shim = require('fabric-shim'); class EzChaincode { async Init(stub) { return shim.success(Buffer.from('init done!'));//返回success对象 } async Invoke(stub) { let key = 'acc0'; let oldValue = await stub.getState(key); //读取账本中acc0的状态 let newValue = oldValue + 100; await stub.putState(key, Buffer.from(newValue)); //更新acc0的状态 return shim.success(Buffer.from('update done!'));//返回success对象 } };
一旦定义好链码,就可以使用shim.start()
方法启动链码实例了。例如:
const shim = require('fabric-shim'); class EzChainCode {...} shim.start(new EzChaincode());
这就是一个完整的Fabric链码了!将上面代码保存为demo.js,可以直接用node.js启动:
~/fabric-shim-chaincode-demo$ node demo.js
fabric-shim是一种相对底层的fabric grpc协议封装,它直接把链码接口暴露给开发者,虽然简单直白,但如果要实现相对复杂一点的链码,开发者需要自己在Invoke实现中进行方法路由。
fabric-contract-api则是更高层级的封装,开发者直接继承开发包提供的Contract类,就不用费心合约方法路由的问题了。fabric-contrac-api开发方法如下:
~/fabric-contract-api-demo$ npm install fabric-contract-api
使用fabric-contract-api的链码示例代码如下,除了构造函数之外的每个方法都自动称为链码的方法,可供外部应用调用 :
//demo.js const { Contract } = require('fabric-contract-api'); class EzContract extends Contract constructor(){ super('EzContract'); } async update(ctx, newValue) { await ctx.stub.putState('acc0', Buffer.from(newValue)); return Buffer.from('update done!'); } async remove(ctx) { //..... } }; module.exports.contracts = ['EzContract'];
与fabric-shim不同,fabric-contract-api只需要链码导出contracts数组,因此不能直接使用node.js启动链码,而需要使用fabric-chaincode-node程序。例如:
~/fabric-contract-api-demo$ fabric-chaincode-node demo.js
关于node.js中怎么实现一个Fabric链码就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。