农产品溯源系统是对农产品从种植到销售的全生命周期进行跟踪的系统。基于农产品溯源数据对相关人员进行追责是保障农产品食品质量安全的重要手段。目前,许多地区已经使用信息系统实现了农产品的溯源跟踪,但相关数据易篡改,溯源信息难可信,事故责任难落实。溯源系统的信用危机严重影响了优质企业的发展。
区块链作为一种去中心化的数据存储技术,其维护的数据具备公开透明、不可篡改等特性。利用区块链技术为相关企业建立信任中心,可以有效地解决农产品溯源系统不安全不可信的问题。
本文总结区块链和溯源技术的发展现状,分析农产品溯源的需求特点,基于Hyperledger Fabric构架 [1],设计一种改进的联盟区块链农产品溯源方案。方案的实施可以进一步巩固相关企业在农产品产销领域的领先地位,对提升全社会农产品安全具有重要意义。
blockchain-fabric-trace: 基于区块链(fabric)农产品溯源平台
注意:node.js尽量用12,如果不想用12也可以使用14,然后安装npm,注意npm一定要用6版本
Ubuntu/Centos中安装最新版node12.*.*版本和npm6.*版本并设置国内镜像
yum install gcc gcc-c++?
(注意要先安装mysql在安装redis,这个redis版本是5.0.7如果需要安装其他版本自己百度)
docker tag hyperledger/fabric-peer:1.2.0 hyperledger/fabric-peer &&?
docker tag hyperledger/fabric-orderer:1.2.0 hyperledger/fabric-orderer &&?
docker tag hyperledger/fabric-ca:1.2.0 hyperledger/fabric-ca &&?
docker tag hyperledger/fabric-tools:1.2.0 hyperledger/fabric-tools &&?
docker tag hyperledger/fabric-ccenv:1.2.0 hyperledger/fabric-ccenv &&?
docker tag hyperledger/fabric-baseimage:0.4.10 ?hyperledger/fabric-baseimage &&?
docker tag hyperledger/fabric-baseos:0.4.10 hyperledger/fabric-baseos &&?
docker tag hyperledger/fabric-couchdb:0.4.10 hyperledger/fabric-couchdb?
这一步按照步骤执行,正常不会出错(出错先看docker是否装好)
chmod -R 777 start.sh
./start.sh
到这一步,首先进入要求的目录下,更改start.sh文件的格式(因为是直接从windows上拖过来的,要更改start.sh的格式 )
?点击小企鹅按钮,然后ctrl+s保存(会弹出一下按钮)直接点击 是的,全部(完成格式修改)
?完成更改格式的步骤后,按照要求赋予权限,运行./start文件
(然后大概率会出错,非常正常第一次执行错误码是7051)解决方法:
有可能有一行执行不成功,只要执行就可以了。
这段代码可以解决这个问题。(然后会出现下一个错误)
版本错误,这个错误也是正常的错误
(注意以下三步都已执行,这个错误是会叠加的具体理解为7051+版本错误)
?第一步:先要进入配置文件etc/resolv.conf 然后把前两行注释掉
?第二步:清除通道(解决版本问题)
有可能有一行执行不成功,只要执行就可以了。注意:最后一行要删除成功
第三步:解决7051问题
再次运行start.sh文件可以执行成功
注:给webapp录下的所用后缀为.sh文件修改格式且赋予权限
注:执行结束后如果第一次执行状态码是200如果再次执行状态码为500,因为已经执行成功一次了,如果出现500的执行状态大可以忽视问题。
node enrollAdmin.js
node registerUser.js
按照要求,第一次大概率出问题,删除掉key重新再试就可以了
node app.js
?启动如果node没有问题的话,不会有问题。如果有问题重装node,重新再来吧。
启动:pm2 start app.js
停止:pm2 stop app.js
可以安装pm2,一行命令解决问题:npm install pm2@latest -g
?如果成功点击消费者溯源会有一下效果,前置Hash下会有内容
?如果没有也不要慌
首先,请确保你使用的地址是正确的,且对应的服务器可以正常访问。如果目标服务器可以正常访问,但你仍然遇到了连接超时错误,可能有以下原因:
网络故障导致请求没有被正确响应。你可以尝试使用其他网络进行请求。
请求被防火墙或其他网络安全设备拦截。请检查你的网络配置,确保请求被正确路由。如果需要,则需添加相应的规则或例外来允许请求通过。
请求的处理时间过长导致超时。你可以尝试调整请求的超时时间,或优化处理过程以提高响应速度。
在尝试以上解决方法后,如果问题仍然存在,你可以尝试联系服务器管理员或相关支持团队来获取更具体的帮助。
关闭防火墙,前往服务器控制台开启所有端口再次查看结果。