fabric2.2学习笔记1

20201303张奕博 2023年1月9日

hyperledger fabric 结构分析

每个Server作用:

AdminServer:控制该节点的命运,可以删除该节点所在的进程。(Start Stop GetStatus )

EventHubServer:Peer节点支持客户端对指定事件进行监听,例如Rejection等。客户端需要先注册自己关心的Events,当事件发生时trigger 监听者。

OpenChainServer:对外提供ledger的访问接口,涉及GetBlockchainInfo GetBlockByNumber等。

DevopsServer:负责与CLI Client对接,外部进行CC操作的入口,Deploy invoke query。

ChaincodeSupportServer:负责与shim/Chaincode通信,ChainCode的所有调用接收发送都要与该Server信息交互。

PeerServer:该Server是一个Engine,Engine关联了内部消息响应实现,同时为周围Peer节点创建Client与之通信。

RESTServer:该Server没有进行分析,应该是REST接口格式相关。

fabric智能合约分析

部分代码截图:

package main

import (
"encoding/json"
"fmt"
"strconv" "github.com/hyperledger/fabric-chaincode-go/shim"
"github.com/hyperledger/fabric-protos-go/peer"
) type Trace struct {
} type CropUpload struct {
CropID string
Timestamp string
Healthy string
Pic string
Action string
Name string
} type ProcessUpload struct {
ProductID string
Timestamp string
Pic string
Process string
Name string
} type BindUpload struct {
ProductID string
CropID string
Timestamp string
Name string
} type TransportUpload struct {
ProductID string
Src string
Dst string
State string
Timestamp string
Name string
} type SaleUpload struct {
ProductID string
Timestamp string
ConsumerName string
Name string
} func (t *Trace) Init(stub shim.ChaincodeStubInterface) peer.Response {
return shim.Success(nil)
} func (t *Trace) Invoke(stub shim.ChaincodeStubInterface) peer.Response {
function, args := stub.GetFunctionAndParameters()
switch function {
case "crop_upload":
return t.recordCrops(stub, args)
case "processing_upload":
return t.recordProcess(stub, args)
case "crop_product_bind":
return t.recordBind(stub, args)
case "transport_upload":
return t.recordTransport(stub, args)
case "sale_upload":
return t.recordSale(stub, args)
case "query":
return t.query(stub, args)
} return shim.Error("Invalid invoke function name. " + function)
}
func (t *Trace) recordCrops(stub shim.ChaincodeStubInterface, args []string) peer.Response {
if len(args) != 6 {
return shim.Error("Invalid args length != 6, length: " + strconv.Itoa(len(args)))
} //将参数填入数据结构中
uploadData := &CropUpload{
CropID: args[0],
Timestamp: args[1],
Healthy: args[2],
Pic: args[3],
Action: args[4],
Name: args[5],
} //将对象序列化成数组存储
m, _ := json.Marshal(uploadData)
// 根据设计文档 创建索引
err := stub.PutState("crpoid#"+uploadData.CropID+"#"+uploadData.Timestamp, m)
if err != nil {
return shim.Error(err.Error())
}
err = stub.PutState("uploadname#"+uploadData.Name+"#"+uploadData.Timestamp, m)
if err != nil {
return shim.Error(err.Error())
} return shim.Success(nil)
} func (t *Trace) recordProcess(stub shim.ChaincodeStubInterface, args []string) peer.Response {
if len(args) != 5 {
return shim.Error("Invalid args length != 5, length: " + strconv.Itoa(len(args)))
} //将参数填入数据结构中
uploadData := &ProcessUpload{
ProductID: args[0],
Timestamp: args[1],
Pic: args[2],
Process: args[3],
Name: args[4],
} //将对象序列化成数组存储
m, _ := json.Marshal(uploadData)
// 根据设计文档 创建索引
err := stub.PutState("productid#"+uploadData.ProductID+"#"+uploadData.Timestamp, m)
if err != nil {
return shim.Error(err.Error())
}
err = stub.PutState("uploadname#"+uploadData.Name+"#"+uploadData.Timestamp, m)
if err != nil {
return shim.Error(err.Error())
} return shim.Success(nil)
} func main() {
if err := shim.Start(new(Trace)); err != nil {
fmt.Printf("Error starting SimpleAsset chaincode: %s", err)
}
}

chaincode验证



进入区块链浏览器验证



数据验证正确

fabric2.2学习笔记1的更多相关文章

  1. js学习笔记:webpack基础入门(一)

    之前听说过webpack,今天想正式的接触一下,先跟着webpack的官方用户指南走: 在这里有: 如何安装webpack 如何使用webpack 如何使用loader 如何使用webpack的开发者 ...

  2. PHP-自定义模板-学习笔记

    1.  开始 这几天,看了李炎恢老师的<PHP第二季度视频>中的“章节7:创建TPL自定义模板”,做一个学习笔记,通过绘制架构图.UML类图和思维导图,来对加深理解. 2.  整体架构图 ...

  3. PHP-会员登录与注册例子解析-学习笔记

    1.开始 最近开始学习李炎恢老师的<PHP第二季度视频>中的“章节5:使用OOP注册会员”,做一个学习笔记,通过绘制基本页面流程和UML类图,来对加深理解. 2.基本页面流程 3.通过UM ...

  4. 2014年暑假c#学习笔记目录

    2014年暑假c#学习笔记 一.C#编程基础 1. c#编程基础之枚举 2. c#编程基础之函数可变参数 3. c#编程基础之字符串基础 4. c#编程基础之字符串函数 5.c#编程基础之ref.ou ...

  5. JAVA GUI编程学习笔记目录

    2014年暑假JAVA GUI编程学习笔记目录 1.JAVA之GUI编程概述 2.JAVA之GUI编程布局 3.JAVA之GUI编程Frame窗口 4.JAVA之GUI编程事件监听机制 5.JAVA之 ...

  6. seaJs学习笔记2 – seaJs组建库的使用

    原文地址:seaJs学习笔记2 – seaJs组建库的使用 我觉得学习新东西并不是会使用它就够了的,会使用仅仅代表你看懂了,理解了,二不代表你深入了,彻悟了它的精髓. 所以不断的学习将是源源不断. 最 ...

  7. CSS学习笔记

    CSS学习笔记 2016年12月15日整理 CSS基础 Chapter1 在console输入escape("宋体") ENTER 就会出现unicode编码 显示"%u ...

  8. HTML学习笔记

    HTML学习笔记 2016年12月15日整理 Chapter1 URL(scheme://host.domain:port/path/filename) scheme: 定义因特网服务的类型,常见的为 ...

  9. DirectX Graphics Infrastructure(DXGI):最佳范例 学习笔记

    今天要学习的这篇文章写的算是比较早的了,大概在DX11时代就写好了,当时龙书11版看得很潦草,并没有注意这篇文章,现在看12,觉得是跳不过去的一篇文章,地址如下: https://msdn.micro ...

  10. ucos实时操作系统学习笔记——任务间通信(消息)

    ucos另一种任务间通信的机制是消息(mbox),个人感觉是它是queue中只有一个信息的特殊情况,从代码中可以很清楚的看到,因为之前有关于queue的学习笔记,所以一并讲一下mbox.为什么有了qu ...

随机推荐

  1. 十二、21.提交本地代码到Git仓库并推送到码云

    查看分支 运行git add . 把所有修改过后文件添加到暂存区 git commit 把当前所有的代码提交到rights分支 加-m加一个消息 到此所有的功能模块都已经提交到了rights这个分支里 ...

  2. 072_关于Dataloader导入Record的创建时间及修改时间并允许owner是Inactive

    1.在User interface 中 启用 Enable "Set Audit Fields upon Record Creation" and "Update Rec ...

  3. 利用context组件数据传递

    react的数据传递 是从父级向子级传递的.通过props.如果是很多组件需要的数据,通过props传递会非常麻烦.这个时候可以使用context. context需要可以类似于store但是也不能滥 ...

  4. [人脸识别]06-JPG人脸检测

    1-程序 #导入CV模块 import cv2 as cv def face_detect_fun(): gray=cv.cvtColor(img,cv.COLOR_BGR2GRAY) print(c ...

  5. Kubernetes--标签选择器(标签)

    标签选择器用于表达标签的查询条件或选择标准,Kubernetes API目前支持两个选择器:基于等值关系(equality-based)以及基于集合关系 (set-based).例如,env=prod ...

  6. pod init 失败

    问题: pod init 失败,报错如下: shenheping@shenhepingdeMacBook-Pro-2 iCar % pod init Ignoring ffi-1.13.1 becau ...

  7. MySQL无法同时执行多条语句解决办法 Dbeaver

    一.场景 说明:在数据库中同时执行多条语句,提示语法错误,如下图: 二.解决办法 第一步:在每条语句最后加上分号(;)表示本条语句结束: 第二步:在数据库连接串上设置 allowMultiQuerie ...

  8. C# load and unload dll

    1. Invoker Any c# project Create a new application domain Create a proxy within the domain Unload th ...

  9. Day23:个人小结的撰写&&对coderunner的熟悉

    今日完成的任务: 1.完成个人小结的撰写 2.阅读Moodle文档,了解Moodle平台以及Moodle出题格式  明日计划: 1.撰写总报告中的结论 2.将插件安装完成 每日小结: 为了研究题库,特 ...

  10. update_base_x.txt

    update g_temp.test_baseset field_date = '20210101'::datewhere field_int = 6