hyperledger fabric的node sdk最新版本为1.4,本文将介绍如何使用最新版本的fabric node sdk开发node.js应用,以实现与fabric区块链的交互,例如查询链码状态,或者提交链码交易。node
本文分五个部分来介绍node.js开发人员如何快速上手fabric node sdk:api
若是但愿高效系统地掌握Fabric区块链的链码及应用开发,建议访问汇智网的在线互动课程:缓存
在hyperledger Fabric区块链架构中,应用是经过节点的RPC协议API接口访问安装在peer节点上的链码:网络
相似于shim api对链码通讯协议的封装,Fabric Node SDK提供了对节点RPC协议接口的封装,其入口类为Client
,通道操做则封装在Channel
类中:架构
因为hyperledger fabric是许可制(Permissioned)区块链,每个参与fabric区块链的成员都须要有明确的身份标识,所以fabric node sdk中的Client
实例须要使用一个User
实例来表征其访问Fabric区块链网络的身份。例如,下面的node.js代码载入本地msp目录中的PEM编码的用户证书与相应的密钥并生成User
对象,而后设置为Client
实例的当前身份:区块链
let client = new Client let keyPem = fs.readFileSync('.msp/keystore/user-key.pem','utf-8') let certPem = fs.readFileSync('./msp/signcerts/user-cert.pem','utf-8') let user = await client.createUser({ //建立User对象 username: 'user', //用户名称 mspid: 'SampleOrg', //所属MSP的ID cryptoContent: { privateKeyPEM: keyPem, //用户私钥 signedCertPEM: certPem //用户证书 }, skipPersistence: true //不计入缓存 }) client.setUserContext(user,true) //设置为client的当前身份
使用Client
实例的newChannel()
方法能够建立一个空的通道对象,咱们还须要添加Peer
和Orderer
实例,以便该通道对象了解要访问的fabric网络的拓扑结构。例如,下面的node.js代码为通道对象配置部署在本机的peer对等节点和orderer排序节点,在默认配置下,对等节点在7051端口监听,而排序节点在7052端口监听:编码
let channel = client.newChannel('ch1') channel.addPeer(client.newPeer('grpc://127.0.0.1:7051')) channel.addOrderer(client.newOrderer('grpc://127.0.0.1:7050'))
在fabric node sdk中,通道对象的queryByChaincode()
方法用于链码状态查询。例如,下面的node.js代码调用链码counter-cc
中定义的value()
方法,以获取计数器的当前值:3d
let req = { chaincodeId: 'counter-cc', fcn: 'value', args: [] } let ret = await channel.queryByChaincode(req)
在fabric node sdk中,向链码提交交易则复杂一些,须要依次使用sendTransactionProposal()
和sendTransaction()
这两个方法,这是由于hyperledger fabric引入了背书(endorsement)机制,在应用向排序节点提交交易以前,须要按照既定的策略首先获取对等节点的背书。code
提交链码交易的时序表示以下:对象
下面的代码展现了在fabric node sdk中链码交易的两阶段提交过程:
let req = { chaincodeId: 'counter-cc', fcn: 'inc', args: ['10'], txId: client.newTransactionID() } let prsp = await channel.sendTransactionProposal(req) //获取peer背书 let rsp = await channel.sendTransaction({ //提交交易 proposalResponses: prsp[0], proposal: prsp[1] })
汇智网原创,转载请标明出处。