Hyperledger中数据存取的实现
簡介
本文介紹了在Hyperledger中數(shù)據(jù)存取的實現(xiàn).
API接口
Hyperledger提供基于key/value的數(shù)據(jù)存儲,其中key是字符串,value則是二進制字節(jié)數(shù)組,Hyperledger的Go API提供了三個方法用于數(shù)據(jù)存取:PutState(key, value)用于向Hyperledger中存儲數(shù)據(jù), GetState(key)用于從Hyperledger中提取數(shù)據(jù),而DelState(key)則從Hyperledger中刪除數(shù)據(jù)。
數(shù)據(jù)存取 Chaincode 示例
以下是一個簡單的數(shù)據(jù)存取Chaincode, 以及其相應的REST請求。
package mainimport ("errors""fmt""github.com/hyperledger/fabric/core/chaincode/shim" )type SaveState1Chaincode struct { }func (t *SaveState1Chaincode) Init(stub shim.ChaincodeStubInterface, function string, args []string) ([]byte, error) {fmt.Printf("Init called with function %s!\n", function)return nil, nil }func (t *SaveState1Chaincode) Invoke(stub shim.ChaincodeStubInterface, function string, args []string) ([]byte, error) {fmt.Printf("Invoke called with function %s!\n", function)var key, value stringkey = args[0]value = args[1]var err errorerr = stub.PutState(key, []byte(value))if err != nil {return nil, err} return nil, nil }func (t *SaveState1Chaincode) Query(stub shim.ChaincodeStubInterface, function string, args []string) ([]byte, error) {fmt.Printf("Query called with function %s!\n", function)var key stringkey = args[0]valInBytes, err := stub.GetState(key)if err != nil {return nil, errors.New("Failed to get state for " + key)}message := "State for " + key + " = " + string(valInBytes)return []byte(message), nil; }func main() {err := shim.Start(new(SaveState1Chaincode))if err != nil {fmt.Printf("Error starting Save State chaincode: %s", err)} }存儲數(shù)據(jù)的REST請求
{"jsonrpc": "2.0","method": "invoke","params": {"type": 1,"chaincodeID":{"name":"mycc"},"ctorMsg": {"function":"invoke","args":["testKey", "testValue"]},"secureContext": "jim"},"id": 3}獲取數(shù)據(jù)的REST請求
{"jsonrpc": "2.0","method": "query","params": {"type": 1,"chaincodeID":{"name":"mycc"},"ctorMsg": {"function":"query","args":["testKey"]},"secureContext": "jim"},"id": 5}關于Immutability
以上代碼也可以看出Hyperledger和BitCoin和Ethereum等區(qū)塊鏈對Immutability的不同理解, 在Hyperledger中,數(shù)據(jù)提交到區(qū)塊鏈后不僅可以改變,還甚至可以被刪除,而在BitCoin和Ethereum中數(shù)據(jù)一旦提交到區(qū)塊鏈后就不能再被改變。
這也體現(xiàn)在R3的Corda區(qū)塊鏈中,R3 CTO Richard Gendal Brown在這里 寫道:
Immutability
The fourth feature in the “Blockchain Bundle” is often, if misleadingly, termed “immutability”: data, once committed, cannot be changed.
This isn’t quite true: if I have a piece of data then of course I can change it. What we actually mean is that: once committed, nobody else will accept a transaction from me if it tries to build on a modified version of some data that has already been accepted by other stakeholders.
Blockchains achieve this by having transactions commit to the outputs of previous transactions and have blocks commit to the content of previous blocks. Each new step can only be valid if it really does build upon an unchangeable body of previous activity.
總結
本文介紹了在Hyperledger中數(shù)據(jù)存取的實現(xiàn)以及關于Immutability的討論.
轉載于:https://www.cnblogs.com/huyouhengbc/p/5967428.html
總結
以上是生活随笔為你收集整理的Hyperledger中数据存取的实现的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 深入浅出mysql第二,mysql-深入
- 下一篇: 下载代码的两种方式ssh 和 https