這篇文章給大家分享的是有關Hyperledger Fabric中鏈碼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 為 true
historyIterator, 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
只支持支持豐富查詢的狀態數據庫CouchDB
queryIterator, 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怎么用”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。