链代码调用
功能介绍
对已经部署并已经实例化的区块链链代码进行调用(invoke)和查询(query)。
URI
POST /v1/chaincode/operation
请求消息
参数 | 是否必选 | 参数类型 | 描述 |
|---|---|---|---|
channelId | 是 | String | 区块链通道ID |
chaincodeId | 是 | String | 链代码ID |
chaincodeVersion | 否 | String | 链代码版本 |
userId | 是 | String | 由组织CA签发的用户ID,目前区块链服务默认生成的都为User1 |
orgId | 是 | String | 区块链组织ID |
orgPeers | 是 | String | 由组织中每个节点的组织ID和域名组成的数组,形如: [{"orgId":"7258adda1803f4137eff4813e7aba323018200c5","peerDomainName":"peer-7258adda1803f4137eff4813e7aba323018200c5-0.peer-7258adda1803f4137eff4813e7aba323018200c5.default.svc.cluster.local"}] |
opmethod | 是 | String | 区块链链码调用类型,目前只有两类调用方法:invoke和query。 |
args | 是 | String | 链码调用参数,形如:["invoke","a","b","1"] |
timestamp | 是 | String | 格式为2018-10-31T17:28:16+08:00 |
cert | 是 | String | 用户的证书文件,以字符串形式上传 |

链码REST API自定义了一些消息头,请参见表2。
名称 | 是否必选 | 描述 |
|---|---|---|
x-bcs-signature-sign | 是 | 链码调用请求消息体签名。 |
x-bcs-signature-method | 是 | 加密类型,目前固定是SW。 |
x-bcs-signature-sign-gzip | 是 | Sign是否选择Gzip压缩。0表示否,1表示是。 |

x-bcs-signature-sign:为了保证只允许有权限的调用端才能够进行合法的链码调用,需要使用下载用户证书中下载的用户私钥以ECDSA椭圆曲线的加密方式对整个请求消息体的SHA256摘要进行加密签名,x-bcs-signature-sign值即为签名结果。
下载用户证书
进行API调用前,需要下载区块链服务中已经配置生成的用户证书。
- 登录区块链服务控制台。
- 进入“实例管理”界面,可以看到已经创建的区块链实例卡片。
- 单击卡片上的“获取客户端配置”,勾选“Peer节点证书”。选择指定节点组织,勾选“用户证书”。
- 单击“下载”,下载相应组织的用户证书。
- 解压证书,其中msp文件夹中,keystore文件夹存储的是组织用户私钥,signcerts文件夹存储的是用户证书(公钥)。
响应消息
- 当opmethod为invoke时,返回值是base64加密的transactionID。
- 当opmethod为query时,返回值是base64加密的链代码的返回值。
示例
下面是调用invoke类型的链代码示例。
- 请求示例
{ "channelId": "testchannel", "chaincodeId": "zmmcode", "chaincodeVersion": "1.0", "userId": "User1", "orgId": "7258adda1803f4137eff4813e7aba323018200c5", "orgPeers": "[{\"orgId\":\"7258adda1803f4137eff4813e7aba323018200c5\",\"peerDomainName\":\"peer-7258adda1803f4137eff4813e7aba323018200c5-0.peer-7258adda1803f4137eff4813e7aba323018200c5.default.svc.cluster.local\"}]", "opmethod": "invoke", "args": "[\"invoke\",\"a\",\"b\",\"1\"]", "timestamp": "2018-10-31T17:28:16+08:00", "cert": "-----BEGIN CERTIFICATE-----\nMIIDBzCCAq2gAwIBAgIQEXPZlMsReamxVtVNnKwCCzAKBggqhkjOPQQDAjCCAQQx\nDjAMBgNVBAYTBUNISU5BMRAwDgYDVQQIEwdCRUlKSU5HMRAwDgYDVQQHEwdCRUlK\nSU5HMXkwdwYDVQQKE3A3MjU4YWRkYTE4MDNmNDEzN2VmZjQ4MTNlN2FiYTMyMzAx\nODIwMGM1LnBlZXItNzI1OGFkZGExODAzZjQxMzdlZmY0ODEzZTdhYmEzMjMwMTgy\nMDBjNS5kZWZhdWx0LnN2Yy5jbHVzdGVyLmxvY2FsMVMwUQYDVQQDE0pjYS5wZWVy\nLTcyNThhZGRhMTgwM2Y0MTM3ZWZmNDgxM2U3YWJhMzIzMDE4MjAwYzUuZGVmYXVs\ndC5zdmMuY2x1c3Rlci5sb2NhbDAeFw0xODEwMzAwMjQ5MjZaFw0yODEwMjcwMjQ5\nMjZaMIG1MQ4wDAYDVQQGEwVDSElOQTEQMA4GA1UECBMHQkVJSklORzEQMA4GA1UE\nBxMHQkVJSklORzF/MH0GA1UEAwx2VXNlcjFANzI1OGFkZGExODAzZjQxMzdlZmY0\nODEzZTdhYmEzMjMwMTgyMDBjNS5wZWVyLTcyNThhZGRhMTgwM2Y0MTM3ZWZmNDgx\nM2U3YWJhMzIzMDE4MjAwYzUuZGVmYXVsdC5zdmMuY2x1c3Rlci5sb2NhbDBZMBMG\nByqGSM49AgEGCCqGSM49AwEHA0IABPMrzoJL/MHeSFPFOJWLqnJ0sqB0it7wDIOq\n+eTSvvPpGk1BIDmb2n13K5V04RO8xNezDQ7I6rW4LF2elq14eH+jTTBLMA4GA1Ud\nDwEB/wQEAwIHgDAMBgNVHRMBAf8EAjAAMCsGA1UdIwQkMCKAIFBXQ5TC4acFeTlT\nJuDZg62XkXCdnOfvbejSeKI2TXoIMAoGCCqGSM49BAMCA0gAMEUCIQCadHIKl0Mk\nYn0WZizyDZYR4rT2q0nzjFaiW+YfV5FBjAIgNalKUe3rIwXJvXORV4ZXurEua2Ag\nQmhcjRnVwPTjpTE=\n-----END CERTIFICATE-----\n" } - 响应示例
After invoke the count of a is 188 b is 262
错误码
请参见错误码页面。


