0

我可以通过以下命令从对等方调用链代码:

peer chaincode invoke -o coreOrderer.dip.com:7050 --tls --cafile /etc/hyperledger/tlsca.dip.com-cert.pem --tlsRootCertFiles /etc/hyperledger/fabric/tls/ca.crt -C dipchannel -n mycc --peerAddresses peer0.core.dip.com:7051 -c '{"Args":["query","a"]}'

它有效,我可以在对等日志中看到:

Entry chaincode: name:"mycc"
Exit chaincode: name:"mycc"  (2ms)

我可以在我的链码容器中看到这个调用的结果。

但是当我试图通过 SDK 从我的代码中调用时

    req := channel.Request{
        ChaincodeID: "mycc",
        Fcn:         "query",
        Args:        [][]byte{[]byte("a")},
    }
    resp, err := client.Execute(req)

我有空响应,在对等日志中我看到:

Entry chaincode: name:"cscc"
Exit chaincode: name:"cscc"  (1ms)

Entry chaincode: name:"lscc"
Exit chaincode: name:"lscc"  (1ms)

为什么它调用“cscc”和“lscc”链码而不调用“mycc”?

4

1 回答 1

0

检查下面是系统链码

LSCC生命周期系统链码处理上述生命周期请求。>>>链码生命周期

CSCC配置系统链码在对等端处理通道配置。>>>这有助于规范访问控制

QSCC Query 系统链码提供账本查询 API,例如获取区块和交易。

注意:特别是,安装、实例化和升级不适用于系统链码。

Hyperledger Fabric 中使用系统链码来实现许多系统行为,以便系统集成商可以根据需要替换或修改它们。

与用户链码不同,系统链码不会使用来自 SDK 或 CLI 的提案进行安装和实例化。它在启动时由对等方注册和部署

来到您的查询>>>>

检查您是否提供身份,因为它进入作为 ACL 监管机构的 CSCC

检查下面我的代码片段

func (setup *FabricSetup) Query() (string, error) {
    // Channel client is used to query and execute transactions
    clientContext := setup.sdk.ChannelContext(setup.ChannelID, fabsdk.WithUser(setup.OrgAdmin))
    client, err := channel.New(clientContext)
    setup.client = client
    // Prepare arguments
    var args []string
    args = append(args, "queryRate")
    args = append(args, "001")

    response, err := setup.client.Query(
        channel.Request{
            ChaincodeID: setup.ChainCodeID,
            Fcn:         args[0],
            Args:        [][]byte{[]byte(args[1])},
        },
    )
    if err != nil {
        return "", fmt.Errorf("failed to query: %v", err)
    }

    return string(response.Payload), nil
}
于 2019-08-22T05:56:29.560 回答