Fabric-CA是什么工具
Fabric-CA是什么工具
小编给大家分享一下Fabric-CA是什么工具,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!
Fabric-CA是Hyperledger Fabric自带的证书管理工具,对于开发和测试非常方便。在这个教程中我们将探索Fabric-CA的使用方法并利用它完成用户的注册/Register和登记/Enrollment。
Hyperledger Fabric是一个许可制的区块链平台,在访问Fabric网络之前必须先进行身份识别并获得访问许可。Fabric网络中的身份是使用数字证书实现的,因此需要CA来处理证书的管理。
虽然Hyperledger Fabric允许使用第三方CA软件来管理用户证书,但出于方便考虑也自带了一个Fabric CA工具可以作为Fabric网络中的CA。由于Fabric自带的应用实例都是使用Fabric CA,因此我们在这个教程中将探索Fabric CA,特别是它在用户注册登记中的应用。
在这片文章中,我们使用部署在First网络上的Fabcar应用,这个实例应用包含了链码和客户端应用,其中的enrolAdmin.js和registerUser.js实现了基于Fabric CA的注册登记。
为了让整个过程展示的更清晰,我们调整了代码。同时我们也会查看Fabric CA的数据库,以便更好的理解在登记和注册时Fabric CA的运行机制。
1、安装
我们需要一个Fabric节点来运行Fabric CA的演示,它应当包含Hyperledger Fabric相关的所有软件。如果你还没有Fabric节点,可以参考这篇文章创建一个。
一旦准备好了Fabric节点,可以运行如下命令启动Fabcar演示:
cdfabric-samples/fabcar./startFabric.sh
这个脚本会启动First网络,以及每个机构的CA。让我们先重点关注Org1的Fabric-CA。
我们使用Fabcar应用中的JavaScript代码,特别是enrollAdmin.js和registerUser.js,因为这两部分代码都是用SDK来访问Fabric CA和Fabric网络。
这就是First网络以及客户端应用与Fabric网络交互的示意。让我们再次关注ca_peerOrg1以及进行登记注册的代码。
2、Fabric CA注册登记代码
访问Fabric CA涉及到两个流程。登记(enrollment)指的是用户从指定CA请求并获取数字证书,注册(registration)通常由注册员完成,他负责告诉CA签发数字证书。
给用户签发数字证书有几种不同的方式。Fabcar脚本所采用的流程类似下面这样:
在Fabric CA中登记管理员,然后管理员收到签名私钥和证书,这些资料存放在 wallet/admin目录下
管理员在Fabric CA中注册user1,CA返回一个密文
CA返回的密文用于在Fabric CA中登记user1,登记后得到user1的签名私钥和证书。这些资料存放在wallet/user1目录下,将被用于后续执行链码交互(查询、交易)。
enrollAdmin.js执行步骤1,registerUser.js执行步骤2和3:
3、修改Fabric CA示例代码
我们没有修改enrollAdmin.js,它只是简单地使用默认地管理员信息(admin:adminpw),这些信息预置在fabric-samples/first-network/目录下的docker-compose-ca.yaml。结果就是admin的签名私钥和证书,保存在wallet/admin目录。
regsiterUser.js被拆分为两个文件:regUser.js和enrollUser.js,这么做的原因在于:
我们可以观察到Fabric CA用户注册和登记的差异之处。
我们可以看到这两个步骤实际上是由不同的角色执行的:注册步骤 是由注册员(admin)操作,而登记步骤则是用户自己使用得到的密文 来完成,这很重要,因为只有用户自己才可以知道密钥,管理员也不应当知道。
我们可以把代码中的硬编码部分抽出来作为参数,这可以让代码适应Fabric CA的其他应用场景。
下面是重写代码后的示意:
4、Fabric CA用户注册:regUser.js
regUser.js需要一个参数:登记ID,返回结果是一个密文,稍后该密文将用于用户登记。注意regUser.js的执行需要Fabric CA中存在admin钱包。
noderegUser.js<enrollmentID>
代码大部分拷贝自原来的registerUser.js:
/**SPDX-License-Identifier:Apache-2.0*/'usestrict';const{FileSystemWallet,Gateway,X509WalletMixin}=require('fabric-network');constpath=require('path');constccpPath=path.resolve(__dirname,'..','..','first-network','connection-org1.json');asyncfunctionmain(){try{//Createanewfilesystembasedwalletformanagingidentities.constwalletPath=path.join(process.cwd(),'wallet');constwallet=newFileSystemWallet(walletPath);console.log(`Walletpath:${walletPath}`);constuser=process.argv[2];//Checktoseeifwe'vealreadyenrolledtheuser.constuserExists=awaitwallet.exists(user);if(userExists){console.log('Anidentityfortheuser'+user+'alreadyexistsinthewallet');return;}//Checktoseeifwe'vealreadyenrolledtheadminuser.constadminExists=awaitwallet.exists('admin');if(!adminExists){console.log('Anidentityfortheadminuser"admin"doesnotexistinthewallet');console.log('RuntheenrollAdmin.jsapplicationbeforeretrying');return;}//Createanewgatewayforconnectingtoourpeernode.constgateway=newGateway();awaitgateway.connect(ccpPath,{wallet,identity:'admin',discovery:{enabled:true,asLocalhost:true}});//GettheCAclientobjectfromthegatewayforinteractingwiththeCA.constca=gateway.getClient().getCertificateAuthority();constadminIdentity=gateway.getCurrentIdentity();//Registertheuser,enrolltheuser,andimportthenewidentityintothewallet.constsecret=awaitca.register({affiliation:'org1.department1',enrollmentID:user,role:'client'},adminIdentity);console.log('Successfullyregistereduser'+user+'andthesecretis'+secret);}catch(error){console.error(`Failedtoregisteruser${user}:${error}`);process.exit(1);}}main();
5、Fabric CA登记用户:enrollUser.js
enrollUser.js需要两个参数,登记ID和注册时得到的密文,返回的结果是在wallet目录中创建的钱包。注意enrollUser.js的运行不需要Fabric CA中admin钱包的存在。该文件应当由用户自己执行。
nodeenrollUser.js<enrollmentID><secret>
代码大部分来自原始的enrollAdmin.js:
/**SPDX-License-Identifier:Apache-2.0*/'usestrict';constFabricCAServices=require('fabric-ca-client');const{FileSystemWallet,X509WalletMixin}=require('fabric-network');constfs=require('fs');constpath=require('path');constccpPath=path.resolve(__dirname,'..','..','first-network','connection-org1.json');constccpJSON=fs.readFileSync(ccpPath,'utf8');constccp=JSON.parse(ccpJSON);asyncfunctionmain(){try{//CreateanewCAclientforinteractingwiththeCA.constcaInfo=ccp.certificateAuthorities['ca.org1.example.com'];constcaTLSCACerts=caInfo.tlsCACerts.pem;constca=newFabricCAServices(caInfo.url,{trustedRoots:caTLSCACerts,verify:false},caInfo.caName);//Createanewfilesystembasedwalletformanagingidentities.constwalletPath=path.join(process.cwd(),'wallet');constwallet=newFileSystemWallet(walletPath);console.log(`Walletpath:${walletPath}`);constuser=process.argv[2];constsecret=process.argv[3];//Checktoseeifwe'vealreadyenrolledtheadminuser.constuserExists=awaitwallet.exists(user);if(userExists){console.log('Anidentityforthisuseralreadyexistsinthewallet');return;}//Enrolltheadminuser,andimportthenewidentityintothewallet.constenrollment=awaitca.enroll({enrollmentID:user,enrollmentSecret:secret});constidentity=X509WalletMixin.createIdentity('Org1MSP',enrollment.certificate,enrollment.key.toBytes());awaitwallet.import(user,identity);console.log(`Successfullyenrolleduser${user}andimporteditintothewallet`);}catch(error){console.error(`Failedtoenrolladminuser"admin":${error}`);process.exit(1);}}main();
6、演示
现在我们看一下如何使用这三个脚本来为Fabcar应用在Fabric CA中注册登记user1用户。
第一步,运行fabcar/startFabric.sh
在运行前确保Fabric CA的钱包目录是空的。
cdfabric-samples/fabcar./startFabric.shcdjavascriptrm-rfwallet
结果如下:
第二步,安装依赖模块。
npminstall
第三步,为org1的Fabric CA安装sqlite3
因为我们要查看Fabric CA的数据库,所有安装sqlite3。
打开另一个终端:
dockerexec-itca_peerOrg1bash
为 ca_peerOrg1安装sqlite3:
apt-getupdateapt-getinstallsqlite3
Fabric CA的数据库路径为:/etc/hyperledger/fabric-ca-server/fabric-ca-server.db,现在我们可以查看一下数据库:
cd/etc/hyperledger/fabric-ca-serversqlite3fabric-ca-server.db
现在已经进入了sqlite3的命令行:
sqlite>.tables
结果如下:
我们的兴趣在于Fabric CA的users表和certificates表,用SQL语句查看其内容:
sqlite>select*fromusers;sqlite>select*fromcertificates;
结果如下:
我们看到用户admin已经在数据库里。这是Fabric CA启动时生成的,这个admin几乎有所有的角色,但目前还没有生成证书。
现在我们可以开始第一个登记了:登记admin。
第四步,在Fabric CA中登记admin
首先登记admin来获得其签名私钥和证书,结果存放在wallet/admin:
nodeenrollAdmin.js
结果:
现在再看一下users表:
可以看到admin的某个字段从0变成了1,这是其状态字段,表示已经签发了证书。
如果我们快速将其与Fabric CA钱包目录wallet/admin中的文件对比,就会看到admin的真实证书:
现在在Fabric CA中注册user1:
noderegUser.jsuser1
结果如下:
我们现在收到密文MDfRiAUccsna,在用户登记时需要这个密文。在Fabric CA的钱包目录,我们还没有看到user1的钱包。
这时查看Fabric CA数据库就可以清晰地看到发生的事情。我们看到users1被添加到users表中,但是其证书还未签发。user1的属性与regUser.js的信息一致。另外,user1的状态是0,表示其证书还未签发。
第五步,在Fabric CA中登记user1,获取私钥和证书
运行enrollUser.js来登记user1:
nodeenrollUser.jsuser1MDfRiAUccsna
结果如下:
我们看到user1现在出现在Fabri CA的钱包里了。我们也看到在Fabric CA数据库中user1的证书已创建:
状态从0迁移到1,表示证书已签发:
第六步,用user1运行查询脚本,检查是否有权限
nodequery.js
结果如下:
以上是“Fabric-CA是什么工具”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注恰卡编程网行业资讯频道!
推荐阅读
-
hyperledger fabric中Raft共识插件的示例分析
-
fabric Transient Data与Private Data使用的示例分析
-
Fabric Node SDK中CouchDB钱包怎么用
-
Fabric链码开发的原则有哪些
Fabric链码开发的原则有哪些这篇文章主要介绍了Fabric链码...
-
fabric示例e2e_cli中network_setup.sh流程是怎么样的
-
Fabric 2.0中链码操作过程是怎么样的
-
如何实现Fabric区块链基于Prometheus和StatsD的运维监控
-
如何下载Fabric-Sampl与二进制包
-
Fabric2.0中first-network生成配置的示例分析
-
fabric go sdk是什么