基于Hyperledger Fabric+CP-ABE加密的溯源类应用系统

        加密机制中有ABE属性加密,属性基加密一般又分为两类,即密钥策略属性基加密(KP-ABE)和密文策略属性基加密(CP-ABE)。

        今天我们重点说一下cp-abe及如何与fabric区块链技术相结合来建设相关溯源、确权、认证等区块链项目应用。(企鹅)。846412999。尤其对具有访问权限的系统如基于区块链的病历管理系统,基于区块链的学历管理系统等等。

CP-ABE加密技术
        为 CP-ABE 加密机制,图中对加密密文的访问策略 AC-CP采用树结构来描述,在 CP-ABE 加密机制中,属性集 Au 是由用户的个人信息提取出的关键信息集合,用户密钥的生成基于属性集 Au,对加密的密文,只有当用户属性集 Au 满足密文的访问策略时,才能解密该密文。CP-ABE 机制与基本 ABE 机制不同之处在于密钥生成与加密算法不同,且在 CP-ABE 机制中,公共参数 PK 和主密钥 MK 的长度与属性集 Au 的大小无关。在 CP-ABE 机制中为了防止用户串谋,将不同的密钥合二为一,KeyGen 密钥生成算法采用两级随机掩码方式,用户密钥的生成与 2 级随机数有关。CP-ABE 机制的加密算法与 KP-ABE 的解密算法类似,都需构建树状的访问策略,区别在于根节点 r的 pr(0)=s,另一个类似之处在于叶节点对应的密文构建解密算法。

        CP-ABE 使用一般群模型,和 KP-ABE 一样,都能支持比较复杂的策略,适用于需细粒度数据共享的场景。与 KP-ABE 机制不同的是,在 CP-ABE 机制中,由数据发送方规定密文的访问策略,适用于如电子信息系统、社交网站的访问等。

访问控制树(Access Tree)
        访问树是一种用于隐藏源数据密钥的结构。只有符合访问树的条件,才能解出其中的秘密值。访问树是由根节点、非叶节点、叶节点构成的。访问树的节点很独特,举一个简单的例子。假设访问树T有一节点x,子节点数就记为num_x,阈值记为k_x。当x不是叶子节点,那么x在树中就表示为阈值关系(由num_x和k_x决定)。当x是叶节点时,则会代表一个属性att(显然num_x为0,k为1)。

        阈值关系:num_x = x_k即“AND”;x_k<num_x即“num_x个子节点需要满足x_k个的门限关系”,注意x_k=1时即为“OR”。

解密访问树

        当数据访问者满足访问树,则可以通过获取属性中存放的秘密值。然后就可以用拉格朗日公式解出父节点生成多项式的常数项。自下而上,最终可以解出根节点中的常数项,即访问树中隐藏的秘密值。

        区块链与加密技术相结合,根据系统要求设计属性加密访问控制树,并将密文进行上链保存或者结合IPFS技术,将ipfs的哈希值上链保存到区块链,应用从区块链获取ipfs地址或者密文后再根据访问控制数完成数据解密,根据不同角色权限即可完成不同用户的不同访问控制。对于fabric应用的开发,主要还有智能合约的开发和设计,链码开发可以使用go或者java语言,springboot框架开发JAVA Web应用部分。负责为用户提供访问区块链上单据的操作界面,并提供搭建区块链浏览器,可以方便查看区块链上的数据存储情况。可以对框架进行压力测试,并自动生成压测报告(企鹅)。846412999。

        也可以对共识算法改进,pbft算法改进,ipfs结合,多通道实例,等各种场景应用,使用CP-ABE属性加密算法的区块链应用范围也很广,比如区块链农产品溯源,区块链冷链存储、区块链的疫苗监控溯源平台、电动汽车充电交易信息记录溯源系统、疫情健康信息及外出记录监控平台、电子订单溯源系统、智慧物流信息监控溯源系统、学生成绩信息管理溯源系统、基于Hyperledger Fabric区块链技术的智慧图书馆管理系统、农产品溯源系统、区块链茶叶信息溯源平台、区块链药品信息溯源平台、区块链食品信息溯源平台、区块链银行黑名单信息溯源平台、区块链冷链食品疫情防控管理系统、区块链的证书认证及溯源平台、区块链医疗保险报销管理系统、区块链电子医疗处方管理平台、基于区块链的指控过程模型、基于区块链的水稻溯源系统、基于区块链的商品防伪溯源平台、基于fabric区块链的跨境支付交易溯源平台、基于区块链的牲畜溯源平台、基于超级账本的手术病历共享平台、基于区块链技术的果蔬产品溯源平台、基于区块链的养殖溯源平台、酒类信息溯源系统、汽车运行数据溯源系统、医疗捐赠跟踪溯源系统、烟草质量安全追溯,等等都适用于区块链的平台开发,信息溯源和防伪认证。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/25156.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

秋招算法备战第39天 | 62.不同路径、63. 不同路径 II

62. 不同路径 - 力扣&#xff08;LeetCode&#xff09; 按照动态规划五部曲走&#xff0c;非常清晰 class Solution:def uniquePaths(self, m: int, n: int) -> int:dp [[0 for _ in range(n)] for _ in range(m)]for i in range(m):dp[i][0] 1for j in range(n):dp[0][…

c++学习(特殊类设计)[30]

只能在堆上创建对象的类 如果你想要确保对象只能在堆上创建&#xff0c;可以通过将析构函数声明为私有&#xff0c;并提供一个静态成员函数来创建对象。这样&#xff0c;类的实例化只能通过调用静态成员函数来完成&#xff0c;而无法直接在栈上创建对象。 以下是一个示例&…

【开源项目--稻草】Day03

【开源项目--稻草】Day03 1. 续Spring-Security1.1 自定义登录界面 2. 用户注册2.1 将注册页面显示2.2 编写控制器进行测试2.3 编写注册业务逻辑2.4 注册功能的收尾 3. VUE3.1 VUE的基本使用3.1.1 什么是VUE 3.2 使用VUEAjax完善稻草问答的注册功能 1. 续Spring-Security 1.1 …

append()函数

go 内置appned函数 append()函数函数说明代码例子 append()函数 函数说明 append函数是Go语言内置的一个非常常用的函数&#xff0c;用于在切片&#xff08;slice&#xff09;末尾追加元素。它的原理比较复杂&#xff0c;涉及到Go语言中切片的底层实现和内存管理&#xff0c;…

Kubespray-offline v2.21.0-1 下载 Kubespray v2.22.1 离线部署 kubernetes v1.25.6

文章目录 1. 目标2. 预备条件3. vcenter 创建虚拟机4. 系统初始化4.1 配置网卡4.2 配置主机名4.3 内核参数 5. 打快照6. 安装 git7. 配置科学8. 安装 docker9. 下载介质9.1 下载安装 docker 介质9.2 下载 kubespray-offline-ansible 介质9.3 下载 kubernetes 介质 10. 搬运介质…

微信小程序 选择年和月以及回显 使用picker-view组件

<!--选择年月--><view bindtap"pickCalendar">{{year}}年{{month}}月</view><picker-view wx:if"{{open}}" class"fixed-select" indicator-style"height: 50px;" style"width: 100%; height: 300px;"…

6.物联网操作系统信号量

一。信号量的概念与应用 信号量定义 FreeRTOS信号量介绍 FreeRTOS信号量工作原理 1.信号量的定义 多任务环境下使用&#xff0c;用来协调多个任务正确合理使用临界资源。 2.FreeRTOS信号量介绍 Semaphore包括Binary&#xff0c;Count&#xff0c;Mutex&#xff1b; Mutex包…

【2种方法,jmeter用一个正则提取器提取多个值!】

jmeter中&#xff0c;用json提取器&#xff0c;一次提取多个值&#xff0c;这个很多人都会。但是&#xff0c;用正则提取器一次提取多个&#xff0c;是否可以呢&#xff1f; 肯定&#xff0c;很多人都自信满满的说&#xff0c;可以&#xff01;形如&#xff1a;token":&q…

neo4j清空数据库

清空所有Person、 Movie节奈及其所有关系 MATCH (a:Person), (m:Movie) OPTIONAL MATCH (a)-[r1]-(), (m)-[r2]-() DELETE a,r1,m,r2 查询任意数据 MATCH (n) RETURN n 如果没有&#xff0c; 就说明已经删除成功了 这段代码是用Cypher查询语言编写的&#xff0c;用于清空…

协议组合逻辑学习笔记

1.challenge 面临的挑战是 通过组合各部分的独立证明 来建立 复合协议的安全性证明。但组合是一个困难的问题&#xff0c;因为一个组件 泄露的信息并不会影响其自身的安全性&#xff0c;但会降低其他组件的安全性&#xff01; 因为即使 各个部分的独立证明可能已经确保了它们…

JS 原型与继承

本文内容学习于&#xff1a;后盾人 (houdunren.com) 一、原型对象 每个对象都有一个原型prototype对象&#xff0c;通过函数创建的对象也将拥有这个原型对象。 原型是一个指向对象的指针。 1.可以将原型理解为对象的父亲&#xff0c;对象从原型对象继承来属性 2.原型就是对象…

Jenkins触发器时间、次数设定

触发器触发条件介绍 触发器触发条件公式&#xff1a;由5颗星组成 * * * * * 分别代表&#xff1a;分钟(0-59) 小时(0-23) 日期(1-31) 月份(1-12) 星期(0-6) 企业项目中常用场景介绍 场景1&#xff1a;接口脚本部分测试通过&#xff0c;部分还在进行&#xff0c;回归测试脚本执行…

Windows上安装 jdk 环境并配置环境变量 (超详细教程)

&#x1f468;‍&#x1f393;博主简介 &#x1f3c5;云计算领域优质创作者   &#x1f3c5;华为云开发者社区专家博主   &#x1f3c5;阿里云开发者社区专家博主 &#x1f48a;交流社区&#xff1a;运维交流社区 欢迎大家的加入&#xff01; &#x1f40b; 希望大家多多支…

torchvision.datasets数据加载失败

torchvision.datasets数据加载失败 如何使用torchvision.datasets进行自动下载数据失败&#xff0c;可以使用手动下载数据 Ctrl点击可以进入相关包文件&#xff0c;查找下载地址&#xff1a;https://www.cs.toronto.edu/~kriz/cifar-10-python.tar.gz 手动下载之后解压&#x…

企业微信小程序在调用wx.qy.login时返回错误信息qy.login:fail

原因是大概是绑定了多个企业但是在开发者工具中没有选择正确的企业 解决方法&#xff1a; 重新选择企业后即可成功获取code

指针常量与常量指针的区别、含指针的函数、什么是结构体

const int *p &a;//定义常量指针&#xff0c;值不可改 int * const p &a;//定义指针常量&#xff0c;指向的值可改&#xff0c;指向不可改 const为静态常量的意思&#xff0c;不可修改。从左到右&#xff0c;常量const先出现&#xff0c;指针符号*后出…

在CSDN学Golang场景化解决方案(基于grpc的微服务开发脚手架)

一&#xff0c;服务与服务之间采用TLS加密通信 在Golang基于gRPC的微服务开发中&#xff0c;可以采用TLS加密通信来确保服务与服务之间的安全通信。下面是一个简单的设计示例&#xff1a; 生成证书和密钥&#xff1a; $ openssl req -newkey rsa:2048 -nodes -keyout server…

Redis 持久化RDB和AOF

Redis 持久化之RDB和AOF Redis 有两种持久化方案&#xff0c;RDB &#xff08;Redis DataBase&#xff09;和 AOF &#xff08;Append Only File&#xff09;。如果你想快速了解和使用RDB和AOF&#xff0c;可以直接跳到文章底部看总结。本章节通过配置文件&#xff0c;触发快照…

RabbitMQ(一) - 基本结构、SpringBoot整合RabbitMQ、工作队列、发布订阅、直接、主题交换机模式

RabbitMQ结构 Publisher &#xff1a; 生产者 Queue: 存储消息的容器队列&#xff1b; Consumer:消费者 Connection&#xff1a;消费者与消息服务的TCP连接 Channel:信道&#xff0c;是TCP里面的虚拟连接。例如&#xff1a;电缆相当于TCP&#xff0c;信道是一条独立光纤束&…

web开发中的安全和防御入门——csp (content-security-policy内容安全策略)

偶然碰到iframe跨域加载被拒绝的问题&#xff0c;原因是父页面默认不允许加载跨域的子页面&#xff0c;也就是的content-security-policy中没有设置允许跨域加载。 简单地说&#xff0c;content-security-policy能限制页面允许和不允许加载的所有资源&#xff0c;常见的包括&a…