/fabric-iot

fabric-iot is a Blockchain Based Decentralized Access Control System in IoT

Primary LanguageShell

fabric-iot 是一个基于Hyperledger Fabric框架实现的物联网访问控制管理的区块链模拟实验平台

English

WHAT WE HAVE:
1.采用ABAC作为权限控制方法,用golang实现了chaincode.
2.编写了完整的脚本,轻松启动fabric-iot网络.
3.详细的步骤说明,浅显易懂.

0.准备工作

0.0.官网

github : hyperledger-fabric
doc 1.4 node-sdk 1.4

0.1.操作系统

OS 版本
mac os >=10.13
ubuntu 16.04

0.2.软件:

软件 版本
git >=2.0.0
docker >=19
docker-compose >=1.24
node >=12
golang >=1.10
Hyperledger Fabric =1.4.*

*请将golang、node的\bin加入PATH

*本次实验基于Fabric 1.4.3,默认下载的Fabric版本是1.4.3

*如果需要修改版本,请更改 bootstrap.sh

VERSION=1.4.3

CA_VERSION=1.4.3

0.3.下载本软件

go get github.com/newham/fabric-iot

0.4.下载并配置Hyperledger Fabric

下载源码和bin

./bootstrap.sh

export PATH

export PATH=$PATH:$(pwd)/fabric-samples/bin

*之后的诸如【启动网络、安装链码等操作需要先export PATH,这是让系统知道Hyperledger Fabric的bin目录】

*也可将其加入path中

1.目录结构

|-chaincode....................................链码目录
|--go....................................................golang编写的chaincode代码
|-client............................................交互客户端
|--nodejs..............................................nodejs编写的客户端代码
|-network........................................fabric-iot网络配置和启动脚本
|--channel-artifacts..............................channel配置文件,创世区块目录
|--compose-files...................................docker-compose文件目录
|--conn-conf.........................................链接docker网络配置目录
|--crypto-config....................................存放证书、秘钥文件目录
|--scripts...............................................cli运行脚本目录
|--ccp-generate.sh...............................生成节点证书目录配置文件脚本
|--ccp-template.json.............................配置文件json模板
|--ccp-template.yaml.............................配置文件yaml模板
|--clear-docker.sh................................清理停用docker镜像脚本
|--configtx.yaml....................................configtxgen的配置文件
|--crypto-config.yaml...........................生成证书、秘钥的配置文件
|--down.sh............................................关闭网络shell脚本
|--env.sh...............................................其他shell脚本import的公共配置
|--generate.sh......................................初始化系统配置shell脚本
|--install-cc.sh......................................安装链码shell脚本
|--rm-cc.sh...........................................删除链码shell脚本
|--up.sh................................................启动网络shell脚本

2.搭建网络 分布式版本

2.1.生成证书、配置文件等

进入目录

cd network

运行脚本

./generate.sh

证书保存在crypto-config

2.2.启动网络

./up.sh

2.3.安装链码

./cc-install.sh

*2.4.更新链码(本步骤在修改了chain code代码后再执行,[new version]要大于上一个版本)

./cc-upgrade.sh [new version]

*chaincode被保存在/chaincode/go目录中,目前只用golang实现

*2.5.关闭网络

./down.sh

*每次关闭网络会删除所有docker容器和镜像,请谨慎操作

3.与区块链交互

3.1.使用shell脚本调用链码

进入shell脚本目录

cd network

调用链码(示例代码在cc-test.sh)

# invoke
# shell|action|cc_name|cc_version|cc_src|fname|args
# add policy
./cc.sh invoke pc 1.0 go/pc AddPolicy '"{\"AS\":{\"userId\":\"13800010001\",\"role\":\"u1\",\"group\":\"g1\"},\"AO\":{\"deviceId\":\"D100010001\",\"MAC\":\"00:11:22:33:44:55\"}}"'
# query policy
./cc.sh invoke pc 1.0 go/pc QueryPolicy '"40db810e4ccb4cc1f3d5bc5803fb61e863cf05ea7fc2f63165599ef53adf5623"'

3.2.使用 Node JS 客户端调用链码

3.2.1初始化代码

进入客户端代码目录
*目前只实现了nodejs的客户端

cd client/nodejs

安装依赖

npm install

3.2.2.创建用户

创建管理员账户

node ./enrollAdmin.js

用管理员账户创建子用户

node ./registerUser.js

3.2.3.调用chaincode

node ./invoke.js [chaincode_name] [function_name] [args]


©2019 liuhanshmtu@163.com all rights reserved.