本实例是一个简单的资产交易平台链码,只能作为学习使用,不能用于线上发布
编写本链码前请先按照
Hyperledger-fabric
系列文章搭建好必要的环境。
编写链码实例
进入上一篇文章创建好的目录中
$GOPATH/src/github.com/silver-g/fabric_asset/deploy
,创建chaincodeAsset
文件夹,并创建asset.go
文件,并编写链码
编写chaincode
本实例在fabric network
启动的情况下,根据docker-compose.yaml
文件中的映射会直接将本文件传入到docker
指定的位置中
创建新的channel并运行chaincode
-
生成创世区块及通道请参考 - 搭建网络环境
-
启动网络(如果网络是启动的可以略过这一步,
-d
参数表示后台运行,第一次运行链码建议不要加-d
参数,这样可以查看启动日志 )docker-compose up -d
启动成功
-
启动网络并进入交互执行窗口
docker exec -it cli bash
-
创建通道
peer channel create -o orderer.example.com:7050 -c assetschannel -f /opt/gopath/src/github.com/hyperledger/fabric/peer/config/assetschannel.tx
-
加入通道
peer channel join -b assetschannel.block
-
查看
channel
列表peer channel list
-
安装链码
peer chaincode install -n assets -v 1.0.0 -l golang -p github.com/chaincode/assetsExchange
-
实例化链码
peer chaincode instantiate -o orderer.example.com:7050 -C assetschannel -n assets -l golang -v 1.0.0 -c '{"Args":["init"]}'
-
链码调用
9.1 注册账户peer chaincode invoke -C assetschannel -n assets -c '{"Args":["userRegister","user1","user1"]}'
9.2 用户查询
peer chaincode invoke -C assetschannel -n assets -c '{"Args":["queryUser","user1"]}'
9.3 资产登记
peer chaincode invoke -C assetschannel -n assets -c '{"Args":["assetEnroll","asset1","asset1","metadata","user1"]}'
9.4 资产查询
peer chaincode invoke -C assetschannel -n assets -c '{"Args":["queryAsset","asset1"]}'
9.5 查询用户资产绑定
peer chaincode invoke -C assetschannel -n assets -c '{"Args":["queryUser","user1"]}'