标签:www. byte oct reg 步骤 为什么 href hyper tab
介绍Hyperledger Fabric CA的命令行方式简单用法
Hyperledger Fabric CA由server和client两部分组成。
设置两个环境变量
export FABRIC_CA_SERVER_HOME=/path_to/fabric-ca/server export FABRIC_CA_CLIENT_HOME=/path_to/fabric-ca/client
server的操作主要有两个:
在server启动之前,需要至少有一个自我认证的身份存在,这个步骤主要会创建这个自我认证的身份。
${FABRIC_CA_SERVER_HOME}/fabric-ca-server init -b admin:adminpw 2017/10/09 13:44:47 [INFO] Created default configuration file at /path_to/fabric-ca/server/fabric-ca-server-config.yaml 2017/10/09 13:44:47 [INFO] generating key: &{A:ecdsa S:256} 2017/10/09 13:44:47 [INFO] encoded CSR 2017/10/09 13:44:47 [INFO] signed certificate with serial number 140063197993174970535175712880510082344059841460 2017/10/09 13:44:47 [INFO] The CA key and certificate were generated for CA 2017/10/09 13:44:47 [INFO] The key was stored by BCCSP provider ‘SW‘ 2017/10/09 13:44:47 [INFO] The certificate is at: /path_to/fabric-ca/server/ca-cert.pem 2017/10/09 13:44:47 [INFO] Initialized sqlite3 database at /path_to/fabric-ca/server/fabric-ca-server.db 2017/10/09 13:44:47 [INFO] Home directory for default CA: /path_to/fabric-ca/server 2017/10/09 13:44:47 [INFO] Initialization was successful
命令执行完成后生成如下4个文件:
其中${FABRIC_CA_SERVER_HOME}/fabric-ca-server.db是一个sqlite文件,包含三个表:
1. table affiliations name VARCHAR(64) | prekey VARCHAR(64) ------------------+--------------------+ org1 | | org1.department1 |org1 | org1.department2 |org1 | org2 | | org2.department1 |org2 | ------------------+--------------------+ 2. table certificates <no date> 3. table users id VARCHAR(64) | token bytea | type VARCHAR(64) | affiliation VARCHAR(64) | attributes VARCHAR(256) | state INTEGER | max_enrollments INTEGER | ----------------+-------------------------------------------------------------+------------------+-------------------------+--------------------------+---------------+---------------------------+ admin |$2a$10$9AVqV7I8tGvA0GPUbAuTluzTEiJwb1F1MHw2OjywGPqTeIH/5pvH6 |client | | <see bellow> | 0 | -1 | ----------------+-------------------------------------------------------------+------------------+-------------------------+--------------------------+---------------+---------------------------+ attributes=[{"name":"hf.Registrar.DelegateRoles","value":"client,user,validator,auditor"},{"name":"hf.Revoker","value":"1"},{"name":"hf.IntermediateCA","value":"1"},{"name":"hf.Registrar.Roles","value":"client,user,peer,validator,auditor"}]
初始化完成之后就可以启动server。
${FABRIC_CA_SERVER_HOME}/fabric-ca-server start -b admin:adminpw 2017/10/09 12:17:04 [INFO] Configuration file location: /path_to/fabric-ca/fabric-ca-server-config.yaml 2017/10/09 12:17:04 [INFO] Starting server in home directory: /path_to/fabric-ca 2017/10/09 12:17:04 [INFO] The CA key and certificate already exist 2017/10/09 12:17:04 [INFO] The key is stored by BCCSP provider ‘SW‘ 2017/10/09 12:17:04 [INFO] The certificate is at: /path_to/fabric-ca/ca-cert.pem 2017/10/09 12:17:04 [INFO] Initialized sqlite3 database at /path_to/fabric-ca/fabric-ca-server.db 2017/10/09 12:17:04 [INFO] Home directory for default CA: /path_to/fabric-ca 2017/10/09 12:17:04 [INFO] Listening on %!s(int=7054)%!(EXTRA string=http://0.0.0.0:7054)
这里,启动过程使用默认的配置文件,即在初始化阶段生成的${FABRIC_CA_SERVER_HOME}/fabric-ca-server-config.yaml,如果需要使用非默认配置文件,只需要通过命令行参数--config指定文件名即可。
另,我们看到server端的主要操作有两步完成,第一步初始化,第二步启动;实际上两步可以合并成一步,即直接执行第二步启动就可以,因为在启动过程中如果发现还没有进行过初始化,那么会自动执行初始化的操作;那为什么需要分成两步呢,因为初始化完成之后用户可能需要对配置文件进行修改,调整参数和配置,然后在启动,而如果直接执行第二步就没有机会修改和调整配置了。
启动完之后可以发送如下命令检查时候工作正常
$ curl -i -uadmin:adminpw -X POST -H "Content-type:application/json" http://localhost:7054/cainfo HTTP/1.1 200 OK Content-Type: application/json Date: Tue, 10 Oct 2017 05:42:16 GMT Content-Length: 1127 { "success":true, "result":{ "CAName":"", "CAChain":"LS0tLS1CRUdJT......tLS0K" }, "errors":[], "messages":[] }
下面三步是客户端的操作
自证管理员是在server启动的时候就内置进去的;后面的很多操作都需要管理员的身份,所以这一步先要获取管理员的身份资格,才能往下操作,比如添加新的角色身份,添加新的管理员等等。
${FABRIC_CA_CLIENT_HOME}/fabric-ca-client enroll -u http://admin:adminpw@localhost:7054 2017/10/09 15:58:40 [INFO] User provided config file: /path_to/fabric-ca/client/fabric-ca-client-config.yaml 2017/10/09 15:58:40 [INFO] Created a default configuration file at /path+_to/fabric-ca/client/fabric-ca-client-config.yaml 2017/10/09 15:58:40 [INFO] generating key: &{A:ecdsa S:256} 2017/10/09 15:58:40 [INFO] encoded CSR 2017/10/09 15:58:40 [INFO] Stored client certificate at /path_to/fabric-ca/client/msp/signcerts/cert.pem 2017/10/09 15:58:40 [INFO] Stored CA root certificate at /path_to/fabric-ca/client/msp/cacerts/localhost-7054.pem
端口7054是server的默认端口,可以在server配置文件里${FABRIC_CA_SERVER_HOME}/fabric-ca-server-config.yaml进行修改。
命令执行完之后生成如下4个文件:
再看server端数据库的变化,可以看到表certificates里面多了一条记录:
1. certificates id VARCHAR(64) | serial_number blob | authority_key_identifier blob | ca_label blob | status blob | reason int | expiry timestamp | revoked_at timestamp | pem blob | ---------------+-----------------------------------------+------------------------------------------+---------------+------------------------------------------------------+---------------------------+----------+ admin | 5b5c9e1859b1798088cf096c7f249301512fdc8 | bf588926fdff01c07124099d0455846fae32ecde | | good | 0 | 2018-10-09 07:54:00+00:00 | 0001-01-01 00:00:00+00:00 | <bellow> | ---------------+-----------------------------------------+------------------------------------------+---------------+------------------------------------------------------+---------------------------+----------+ pem blob= -----BEGIN CERTIFICATE----- MIICVjCCAfygAwIBAgIUBbXJ4YWbF5gIjPCWx/JJMBUS/cgwCgYIKoZIzj0EAwIw aDELMAkGA1UEBhMCVVMxFzAVBgNVBAgTDk5vcnRoIENhcm9saW5hMRQwEgYDVQQK ... A0gAMEUCIQDVO1GO+9k+g7hbuevLh/YRq9LQNptu6IaJOAzLuPdCeQIgcMvfoKuv Y+W2JC70/xbL4yimpt86k55CA/aqyrmq5+0= -----END CERTIFICATE----- 实际上这个pem的内容就是client的证书文件,即${FABRIC_CA_CLIENT_HOME}/msp/signcerts/cert.pem一致。
如下示例,我们使用 admin 的身份及其配套证书,登记了一个名称为 "tester"、类型为 "user"、组织关系为 "org1.department1"、"hf.Revoker" 属性为 "true" 的新角色:
${FABRIC_CA_CLIENT_HOME}/fabric-ca-client register --id.name tester --id.secret testpasswd --id.type user --id.affiliation org1.department1 --id.attrs hf.Revoker=true or ${FABRIC_CA_CLIENT_HOME}/fabric-ca-client register --id.name tester02 --id.secret testpasswd --id.type user --id.affiliation org1.department2 --id.attrs ‘hf.Revoker=true,admin=true:ecert‘
这地方需要注意的是:
再看server端数据库的变化,可以看到表users里面多了一条记录。
1. table users id VARCHAR(64) | token bytea | type VARCHAR(64) | affiliation VARCHAR(64) | attributes VARCHAR(256) | state INTEGER | max_enrollments INTEGER | ----------------+--------------------------------------------------------------+------------------+-------------------------+--------------------------+---------------+---------------------------+ admin | $2a$10$9AVqV7I8tGvA0GPUbAuTluzTEiJwb1F1MHw2OjywGPqTeIH/5pvH6 | client | | <see bellow> | 0 | -1 | tester | $2a$10$kOuCBi8IHk8tAUD9afNtLOYBmiYcse4rLdURILoumuJCI69FVDm2O | user | org1.department1 | <see bellow> | 0 | -1 | ----------------+--------------------------------------------------------------+------------------+-------------------------+--------------------------+---------------+---------------------------+ attributes=[{"name":"hf.Registrar.DelegateRoles","value":"client,user,validator,auditor"},{"name":"hf.Revoker","value":"1"},{"name":"hf.IntermediateCA","value":"1"},{"name":"hf.Registrar.Roles","value":"client,user,peer,validator,auditor"}] attributes=[{"name":"hf.Revoker","value":"true"}]
完成身份登记之后需要做认证。
${FABRIC_CA_CLIENT_HOME}/fabric-ca-client enroll -u http://tester:testpasswd@localhost:7054 or ${FABRIC_CA_CLIENT_HOME}/fabric-ca-client enroll -u http://tester02:testpasswd@localhost:7054 2017/10/09 13:34:52 [INFO] User provided config file: /path_to/fabric-ca-client/fabric-ca-client-config.yaml 2017/10/09 13:34:52 [INFO] generating key: &{A:ecdsa S:256} 2017/10/09 13:34:52 [INFO] encoded CSR 2017/10/09 13:34:52 [INFO] Stored client certificate at /path_to/fabric-ca-client/msp/signcerts/cert.pem 2017/10/09 13:34:52 [INFO] Stored CA root certificate at /path_to/fabric-ca-client/msp/cacerts/localhost-7054.pem
完成角色认证后,再看server端数据库的变化,和自证管理员身份认证一样,会往certificates表里面插入一条数据,其内容是对应角色的证书信息。
总结起来,登记身份和认证身份分别完成的功能是:
这也就是client三个步骤里面,第一步就需要做自证管理员身份的认证操作,因为此时客户端没有任何证书身份信息,只有自证管理员的名字和密码,可以完成自证管理员的认证操作;完成后本地就有自证管理员的身份信息包括证书文件,私钥;有了这些信息,才可以操作接下来的登记其他身份操作,因为登记一个身份需要具有登记权限的人才能做,既然刚才已经完成了自证管理员的认证操作,那么本地身份就是自证管理员,因此可以以自证管理员身份进行其他的登记操作。
另外要注意的是,在认证身份的时候会把之前已经存在的所有配置文件(包括client配置文件,client证书文件,client私钥文件,根证书文件)都重新写掉,文档上说可以通过命令行指定不同的文件名,但是经过试验好像不灵,不知道这是我使用上的问题,还是程序bug。所以在我们例子中当完成用户tester的认证之后,本地的证书信息就被覆盖成tester的了,此时再进行用户登记操作就会失败,因为本地用户已经是tester了,而不是最初的自证管理员了,而tester用户不具有登记用户的权限。办法就是重新认证自证管理员身份。
转自:https://www.jianshu.com/p/2159f9043102
标签:www. byte oct reg 步骤 为什么 href hyper tab
原文地址:https://www.cnblogs.com/zhangmingcheng/p/9111845.html