美文网首页
fabric 私有数据

fabric 私有数据

作者: ccDown | 来源:发表于2019-10-30 17:21 被阅读0次

私有数据:被授权的节点将可以看得到在主账本上的数据哈希,以及在私有数据库中的真实数据。未得到授权的节点将不会同步私有数据库,只能看到在主账本上的数据哈希。由于哈希是不可逆的,因此这些未授权的节点无法看到真实的数据。
在一个fabric交易报文中包含了该交易所有的数据,为了实现交易数据私有化,必须使用一种只有被允许的节点才能看到的数据(临时数据)。因此添加私有数据需要临时数据作为媒介。

交易流程:
1.客户端创建临时数据
2.客户端通过临时数据获取到需要保存的数据,生成hash发送到交易背书节点进行背书,然后发送给排序节点
3.校验通过之后进行私有数据的存储

[
  {
    "name": "collectionBsnBase", #数据库名称
    "policy": "OR('Org1MSP.member')", # 可以持有私有数据的节点成员
    "requiredPeerCount": 0, #作为链码的背书条件,需要将私有数据传播到的节点数量
    "maxPeerCount": 3, #为了数据冗余,现有背书节点需要尝试将数据分发到其他节点的数量。如 果背书节点发生故障,当有请求提取私有数据时,则其他节点在提交时可用。
    "blockToLive":0, #对于非常敏感的信息,比如价格或者个人信息,这个值表示在数据要以区块 的形式在私有数据库中存放的时间。数据将在私有数据库中存在指定数量的区块数然后会被清除, 也就是数据会从网络中废弃。要永久保存私有数据,永远不被清除,就设置 blockToLive 为 0 
    "memberOnlyRead": true #值为 true 则表示节点会自动强制只有属于收集器成员组织的客户端才 有读取私有数据的权限
  }
]

链码安装

peer chaincode install -n cc_privatedata -v 1.0.1 -p marbles02_private/go/

链码实例化(额外指定--collections-config src/marbles02_private/collections_config.json)

peer chaincode instantiate -n cc_privatedata -v 1.0.0 -C cl20191018133906 -c '{"Args":["init"]}' --tls true --cafile certs/ordererOrganizations/chainorder.example.com/orderers/chainorder1.example.com/tls/tlsintermediatecerts/tls-chainorder-example-com.pem - -o orderer1.example.com:17051 --collections-config  src/marbles02_private/collections_config.json

链码升级(额外指定--collections-config src/marbles02_private/collections_config.json)

peer chaincode upgrade  -n cc_privatedata -v 1.0.1 -C cl20191018133906  -c '{"Args":["init"]}' --tls true --cafile certs/ordererOrganizations/chainorder.example.com/orderers/chainorder1.example.com/tls/tlsintermediatecerts/tls-chainorder-example-com.pem - -o orderer1.example.com:17051 --collections-config  src/marbles02_private/collections_config.json

设置临时数据

export MARBLE=$(echo -n "{\"Name\":\"marble1\",\"color\":\"blue\",\"size\":35,\"owner\":\"tom\",\"price\":99}" | base64 | tr -d \\n)

调用链码(额外指定--transient "{"marble":"$MARBLE"}")

peer chaincode invoke -n cc_privatedata -C cl20191018133906 -c '{"Args":["initMarble"]}' --tls true --cafile certs/ordererOrganizations/chainorder.example.com/orderers/chainorder1.example.com/tls/tlsintermediatecerts/tls-chainorder-example-com.pem -o chainorder1.example.com:17051 --transient "{\"marble\":\"$MARBLE\"}"
 peer chaincode query -C cl20191018133906 -n cc_privatedata  -c '{"Args":["readMarble","marble1"]}'

以下是两个安装了该链码的节点的数据库,可以看出来有权限的节点数据库多了一个表,而这个表中存储的就是私有数据的内容

有权限的节点的数据库 没权限的节点的数据库

官方教程:https://hyperledger-fabric-cn.readthedocs.io/zh/latest/private_data_tutorial.html#pd-purge

相关文章

  • 5.6' Hyperledger Fabric - 教程 - 在

    在 Fabric 中使用私有数据 3. 启动网络 Reference Docs » Tutorials » Usi...

  • fabric 私有数据

    私有数据:被授权的节点将可以看得到在主账本上的数据哈希,以及在私有数据库中的真实数据。未得到授权的节点将不会同步私...

  • hyperledger fabric 1.2

    fabric-1.2 channel 私有数据保持 chaincode 数据在一部分 channel 成员之间保密...

  • 5.6 Hyperledger Fabric - 教程 - 在

    在 Fabric 中使用私有数据 本教程将演示如何使用集合为组织的授权对端节点在区块链网络上提供私有数据的存储和检...

  • fabric private data解析

    fabric private data利用SideDB来保存私有数据,相当于在通道之上又提供了一层更细粒度的数据隐...

  • Fabric private data基本概念

    fabric private data利用SideDB来保存私有数据,相当于在通道之上又提供了一层更细粒度的数据隐...

  • 9. Hyperledger Fabric 专题 - 私有数据

    Hyperledger Fabric 专题 - 私有数据 有可能存在这样一种特殊的需求,对于同属于一个通道的多个组...

  • Hyperledger Fabric私有数据(Private D

    说明: 基于Hyperledger Fabric 1.2的源码;自己阅读源码也是在学习和摸索中,有错误的话欢迎指正...

  • Hyperledger-fabric的账本存储

    hyperledger-fabric的账本存储 fabric的账本数据主要包含以下4个部分 区块数据存储 索引数据...

  • fabric1.2.1新特效-私有数据

    私有数据 私有数据的应用 在同一通道内某一组织持有私有数据,只要被认证的组织才可以访问。如果为了保持数据的隐私性而...

网友评论

      本文标题:fabric 私有数据

      本文链接:https://www.haomeiwen.com/subject/buwvvctx.html