Hyperledger中數據存取的實現

簡介

本文介紹了在Hyperledger中數據存取的實現.git

API接口

Hyperledger提供基於key/value的數據存儲,其中key是字符串,value則是二進制字節數組,Hyperledger的Go API提供了三個方法用於數據存取:PutState(key, value)用於向Hyperledger中存儲數據, GetState(key)用於從Hyperledger中提取數據,而DelState(key)則從Hyperledger中刪除數據。github

數據存取 Chaincode 示例

如下是一個簡單的數據存取Chaincode, 以及其相應的REST請求。json

package main

import (
    "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 string
    key = args[0]
    value = args[1]

    var err error
    err = 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 string
    key = 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)
    }
}

存儲數據的REST請求api

{
   "jsonrpc": "2.0",
   "method": "invoke",
   "params": {
       "type": 1,
       "chaincodeID":{
           "name":"mycc"
       },
       "ctorMsg": {
          "function":"invoke",
          "args":["testKey", "testValue"]
       },
       "secureContext": "jim"
   },
   "id": 3
 }

獲取數據的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等區塊鏈對Immutability的不一樣理解, 在Hyperledger中,數據提交到區塊鏈後不只能夠改變,還甚至能夠被刪除,而在BitCoin和Ethereum中數據一旦提交到區塊鏈後就不能再被改變。區塊鏈

這也體如今R3的Corda區塊鏈中,R3 CTO Richard Gendal Brown在這裏 寫道:ui

Immutabilitythis

The fourth feature in the 「Blockchain Bundle」 is often, if misleadingly, termed 「immutability」: data, once committed, cannot be changed.code

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.blog

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中數據存取的實現以及關於Immutability的討論.

相關文章
相關標籤/搜索