这篇文章给大家分享的是有关Hyperledger Fabric中链码shim API怎么用的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。
塔城网站建设公司成都创新互联,塔城网站设计制作,有大型网站制作公司丰富经验。已为塔城上千提供企业网站建设服务。企业网站搭建\成都外贸网站建设要多少钱,请找那个售后服务好的塔城做网站的公司定做!
用 Go 的链码的 shim API 主要方法详解
GetFunctionAndParameters
获取方法名和参数
invoke的参数 : {"Args":["set","a","100"]}fn, args := stub.GetFunctionAndParameters() fmt.Println("GetFunctionAndParameters方法获取方法名和参数:", fn, args) stub.PutState(args[0], []byte(args[1]))
GetStringArgs
获取所有参数字符串数组,包含方法名args = stub.GetStringArgs() fmt.Println("GetStringArgs方法获取所有参数字符串数组,包含方法名:", args)
PutState
设置值
设置key-value 4个(str0-hello0,str1-hello1,str2-hello2,str3-hello3)stub.PutState("str0", []byte("hello0")) stub.PutState("str1", []byte("hello1")) stub.PutState("str2", []byte("hello2")) stub.PutState("str3", []byte("hello3"))
GetStateByRange
获取从key为str0到key为str2的值,返回k-v的迭代器resultIterator, _ := stub.GetStateByRange("str0", "str2") defer resultIterator.Close() fmt.Println("GetStateByRange获取从key为str0到key为str2的值,返回k-v的迭代器,遍历:") for resultIterator.HasNext() { item, _ := resultIterator.Next() fmt.Println(string(item.Key), string(item.Value)) }
GetState 获取对应key的值
a, _ := stub.GetState("a") fmt.Println("GetState方法获取a的值:", string(a))
GetHistoryForKey
获取key的历史值,返回历史迭代器,可以获取历史所在交易id和值
GetHistoryForKey 请求节点配置 core.ledger.history.enableHistoryDatabase 为 truehistoryIterator, err := stub.GetHistoryForKey("a") if err != nil { fmt.Println(err) } else { defer historyIterator.Close() for historyIterator.HasNext() { item, _ := historyIterator.Next() fmt.Println(item.TxId, string(item.Value)) } }
DelState
删除key为a的键值stub.DelState("a") fmt.Printf("DeDelState方法删除key为a的键值,") a, _ = stub.GetState("a") fmt.Println("删除后获取a的值:", string(a))
CreateCompositeKey 创建组合键
indexName := "sex~name" indexKey, _ := stub.CreateCompositeKey(indexName, []string{"boy", "jon"}) fmt.Println("CreateCompositeKey方法创建组合键:", indexKey) stub.PutState(indexKey, []byte("0")) indexKey, _ = stub.CreateCompositeKey(indexName, []string{"boy", "luo"}) fmt.Println("CreateCompositeKey方法创建组合键:", indexKey) stub.PutState(indexKey, []byte("0")) indexKey, _ = stub.CreateCompositeKey(indexName, []string{"girl", "wen"}) fmt.Println("CreateCompositeKey方法创建组合键:", indexKey) stub.PutState(indexKey, []byte("0"))
GetStateByPartialCompositeKey
获取组合键的集合迭代器resultIterator, _ = stub.GetStateByPartialCompositeKey(indexName, []string{"boy"}) defer resultIterator.Close() fmt.Println("GetStateByPartialCompositeKey方法获取有boy的集合迭代器,遍历:") for resultIterator.HasNext() { item, _ := resultIterator.Next() fmt.Println("key: " + item.Key) fmt.Println("value: " + string(item.Value)) objectType, compositeKeyParts, _ := stub.SplitCompositeKey(item.Key) fmt.Println("objectType: " + objectType) fmt.Println("sex : " + compositeKeyParts[0]) fmt.Println("name : " + compositeKeyParts[1]) }
GetQueryResult
couchdb 文档 https://github.com/cloudant/mango
只支持支持丰富查询的状态数据库CouchDBqueryIterator, err1 := stub.GetQueryResult(`{"selector": {"sex": "boy"}}`) if err1 != nil { fmt.Println(err1) } else { defer queryIterator.Close() for queryIterator.HasNext() { item, _ := queryIterator.Next() fmt.Println(item.Key, string(item.Value)) } }
InvokeChaincode
InvokeChaincode方法在本地调用指定的chaincode的方法
同一通道的链码调用另一链码会影响另一链码状态
不同通道的链码调用另一链码不会影响被调用的链码状态,相当于一个查询trans:=[][]byte{[]byte("invoke"),[]byte("a"),[]byte("b"),[]byte("11")} result := stub.InvokeChaincode("mycc",trans,"myc") fmt.Println(result)
GetCreator
获取当前用户creatorByte, _ := stub.GetCreator() certStart := bytes.IndexAny(creatorByte, "-----BEGIN") if certStart == -1 { fmt.Errorf("No certificate found") } certText := creatorByte[certStart:] bl, _ := pem.Decode(certText) if bl == nil { fmt.Errorf("Could not decode the PEM structure") } cert, err := x509.ParseCertificate(bl.Bytes) if err != nil { fmt.Errorf("ParseCertificate failed") } uname := cert.Subject.CommonName fmt.Println("Name:" + uname)
GetQueryResultWithPagination
所有分页功能的方法是1.3版本后才有的
分页丰富查询
只支持支持丰富查询的状态数据库CouchDB
关键的参数 :
pageSize 是分页大小
bookmark 索引, 第一页为空字符串,每次查询都会有下一页的索引的返回,用来做参数继续往下查resultsIterator, responseMetadata, err := stub.GetQueryResultWithPagination(queryString, pageSize, bookmark) if err != nil { return nil, err } defer resultsIterator.Close() var buffer bytes.Buffer buffer.WriteString("[") bArrayMemberAlreadyWritten := false for resultsIterator.HasNext() { queryResponse, err := resultsIterator.Next() if err != nil { return nil, err } if bArrayMemberAlreadyWritten == true { buffer.WriteString(",") } buffer.WriteString("{\"Key\":") buffer.WriteString("\"") buffer.WriteString(queryResponse.Key) buffer.WriteString("\"") buffer.WriteString(", \"Record\":") buffer.WriteString(string(queryResponse.Value)) buffer.WriteString("}") bArrayMemberAlreadyWritten = true } buffer.WriteString("]") if err != nil { return nil, err } buffer.WriteString("[{\"ResponseMetadata\":{\"RecordsCount\":") buffer.WriteString("\"") buffer.WriteString(fmt.Sprintf("%v", responseMetadata.FetchedRecordsCount)) buffer.WriteString("\"") buffer.WriteString(", \"Bookmark\":") buffer.WriteString("\"") buffer.WriteString(responseMetadata.Bookmark) buffer.WriteString("\"}}]") fmt.Printf("- getQueryResultForQueryString queryResult:\n%s\n", buffer.String())
感谢各位的阅读!关于“Hyperledger Fabric中链码shim API怎么用”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!
文章题目:HyperledgerFabric中链码shimAPI怎么用
当前路径:http://scpingwu.com/article/ipjosp.html