我正在尝试通过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的情况下发生的,我无法用那里的答案解决问题,
答案 0 :(得分:0)
您最好检查一下我认为的客户端的用户上下文。
用户上下文具有mspID。检查mspId是否为Org1MSP。
答案 1 :(得分:0)
错误可能是由于证书签署了交易。再次检查您从CA收到的证书,并检查对等体的Docker容器内使用的证书和路径。