Hyperledger Fabric错误:2未知:访问被拒绝:频道[mychannel]创建者单位[Org1MSP]

时间:2018-11-12 12:31:29

标签: hyperledger-fabric hyperledger hyperledger-fabric-ca

我正在尝试通过JavaScript与对等方进行交互,并且不断获得

{ Error: 2 UNKNOWN: access denied: channel [mychannel] creator org [Org1MSP]
    at Object.exports.createStatusError (/blockchain-api-js/node_modules/grpc/src/common.js:87:15)
    at Object.onReceiveStatus (/blockchain-api-js/node_modules/grpc/src/client_interceptors.js:1188:28)
    at InterceptingListener._callNext (/blockchain-api-js/node_modules/grpc/src/client_interceptors.js:564:42)
    at InterceptingListener.onReceiveStatus (/blockchain-api-js/node_modules/grpc/src/client_interceptors.js:614:8)
    at callback (/blockchain-api-js/node_modules/grpc/src/client_interceptors.js:841:24)
  code: 2,
  metadata: [Object],
  details: 'access denied: channel [mychannel] creator org [Org1MSP]' }

我正在使用fabric-ca示例,并且能够从cli和cli通过run-fabric.sh执行事务,但是我似乎无法从JS执行此操作,因此我创建了一个新用户并用client.setTlsClientCertAndKey(cert, key);设置客户端和证书,我什至尝试提供/data/orgs/org1/admin/msp/signcerts, /data/orgs/org1/admin/msp/admincerts/data/orgs/org1/admin/msp/keystore以及/data/tls/的管理员证书和密钥,但是没有运气 这是我使用的代码的一部分:

var channel = this.client.newChannel('mychannel')

    let serverCert = fs.readFileSync('/data/org0-ca-chain.pem');

    channel.addOrderer(
        this.client.newOrderer(
            config.orderers['orderer1-org0'].url,
            {
                pem: Buffer.from(serverCert).toString()
            }
        )
    );

    serverCert = fs.readFileSync('/data/org1-ca-chain.pem');

    const peer1 = this.client.newPeer(
        config.peers['peer1-org1'].url,
        {
            pem: Buffer.from(serverCert).toString()
        }
    );
    channel.addPeer(peer1);
    this.eventhubs = []
    this.eventhubs.push(channel.newChannelEventHub(peer1));

    serverCert = fs.readFileSync('/data/org2-ca-chain.pem');

    const peer2 = this.client.newPeer(
        config.peers['peer1-org2'].url,
        {
            'pem': Buffer.from(serverCert).toString()
        }
    );
    channel.addPeer(peer2);
    this.eventhubs.push(channel.newChannelEventHub(peer2));
    this.channel = channel;
    console.log(this.channel)

    return this.channel.sendTransactionProposal(request);

我的代码或执行方式有问题吗?有人可以告诉我我在做什么错吗?我见过一些类似的问题,但是这些问题是在大多数使用composer的情况下发生的,我无法用那里的答案解决问题,

2 个答案:

答案 0 :(得分:0)

您最好检查一下我认为的客户端的用户上下文。

用户上下文具有mspID。检查mspId是否为Org1MSP。

答案 1 :(得分:0)

错误可能是由于证书签署了交易。再次检查您从CA收到的证书,并检查对等体的Docker容器内使用的证书和路径。