当前位置: 首页 > article >正文

实战指南:用Python模拟实现一个简易的CP-ABE访问树(附完整代码)

实战指南用Python模拟实现一个简易的CP-ABE访问树附完整代码在数据安全领域基于属性的加密Attribute-Based Encryption, ABE正逐渐成为细粒度访问控制的热门技术。其中密文策略ABECP-ABE因其灵活的访问策略定义能力特别适合需要复杂权限管理的场景。本文将带您用Python从零构建一个CP-ABE访问树系统通过代码实现深入理解其核心机制。1. 环境准备与基础概念在开始编码前我们需要明确几个关键概念。CP-ABE的核心在于访问树Access Tree——这是一种将访问策略表示为树形结构的方案。树的叶子节点代表属性而非叶子节点则定义了属性间的逻辑关系如AND、OR等门限条件。安装必要的Python库pip install pycryptodome numpyCP-ABE与KP-ABE的主要区别CP-ABE密文关联访问策略私钥关联属性集合KP-ABE私钥关联访问策略密文关联属性集合提示本文实现的简化版本聚焦于访问树构造和秘密分享机制省略了实际的加密运算部分。2. 核心数据结构设计2.1 多项式类实现访问树的构建依赖于多项式秘密分享技术。我们先实现一个基础的多项式类import random from numpy.polynomial.polynomial import Polynomial class SecretPolynomial: def __init__(self, secret, degree): 初始化一个随机多项式常数项为secret coefficients [secret] [random.randint(1, 100) for _ in range(degree)] self.poly Polynomial(coefficients) def evaluate(self, x): 计算多项式在x处的值 return self.poly(x)2.2 访问树节点类每个节点需要存储以下信息节点类型叶子/非叶子门限值非叶子节点属性名称叶子节点子节点列表秘密值class AccessTreeNode: def __init__(self, node_type, thresholdNone, attributeNone): self.node_type node_type # leaf or interior self.threshold threshold # 仅非叶子节点需要 self.attribute attribute # 仅叶子节点需要 self.children [] self.secret None self.index None # 用于多项式评估 def add_child(self, child_node): self.children.append(child_node)3. 访问树构建与秘密分发3.1 构建示例访问树让我们构建一个学院实验室访问控制的示例树def build_sample_tree(): # 根节点2/3门限 root AccessTreeNode(interior, threshold2) # 第一层子节点 dept_node AccessTreeNode(interior, threshold3) # 3/3 AND条件 teacher_node AccessTreeNode(leaf, attribute教师) lab_node AccessTreeNode(interior, threshold1) # 1/2 OR条件 root.add_child(dept_node) root.add_child(teacher_node) root.add_child(lab_node) # 学院节点子节点 dept_node.add_child(AccessTreeNode(leaf, attribute计算机学院)) dept_node.add_child(AccessTreeNode(leaf, attribute硕士)) dept_node.add_child(AccessTreeNode(leaf, attribute研二)) # 实验室节点子节点 lab_node.add_child(AccessTreeNode(leaf, attribute网络实验室)) lab_node.add_child(AccessTreeNode(leaf, attribute云实验室)) return root3.2 秘密分发算法实现秘密分发过程需要递归遍历整棵树def distribute_secrets(node, parent_secretNone): if node.node_type interior: # 生成多项式次数门限值-1 poly SecretPolynomial(parent_secret if parent_secret else random.randint(1, 100), node.threshold - 1) # 为每个子节点分配秘密值 for i, child in enumerate(node.children, start1): child.secret poly.evaluate(i) child.index i distribute_secrets(child, child.secret) else: # 叶子节点存储最终秘密值 node.secret parent_secret4. 解密过程实现4.1 拉格朗日插值解密过程的核心是拉格朗日插值用于从部分点重建多项式from functools import reduce def lagrange_interpolation(points, x0): 使用拉格朗日插值法计算多项式在x处的值 points: [(x1,y1), (x2,y2), ...] def basis(j): p [(x - points[m][0]) / (points[j][0] - points[m][0]) for m in range(len(points)) if m ! j] return reduce(lambda a, b: a * b, p) return sum(points[j][1] * basis(j) for j in range(len(points)))4.2 递归解密算法def decrypt(node, user_attributes): if node.node_type leaf: # 检查用户是否具有该属性 return node.secret if node.attribute in user_attributes else None # 收集满足条件的子节点秘密 child_secrets [] for child in node.children: secret decrypt(child, user_attributes) if secret is not None: child_secrets.append((child.index, secret)) # 检查是否满足门限条件 if len(child_secrets) node.threshold: return None # 使用拉格朗日插值恢复父节点秘密 return lagrange_interpolation(child_secrets)5. 完整示例与测试让我们测试整个系统# 构建并初始化访问树 tree build_sample_tree() distribute_secrets(tree) # 定义不同用户的属性集 user1 [计算机学院, 硕士, 研二, 教师] # 应能解密 user2 [计算机学院, 硕士, 网络实验室] # 应能解密 user3 [教师, 云实验室] # 应能解密 user4 [硕士, 研二] # 应不能解密 # 测试解密 print(User1解密结果:, decrypt(tree, user1)) print(User2解密结果:, decrypt(tree, user2)) print(User3解密结果:, decrypt(tree, user3)) print(User4解密结果:, decrypt(tree, user4))典型输出可能如下User1解密结果: 42 User2解密结果: 42 User3解密结果: 42 User4解密结果: None注意实际应用中解密得到的秘密值会用于派生加密密钥。本示例为简化实现省略了后续的加密/解密步骤。6. 性能优化与扩展6.1 多项式生成优化原始实现中每次递归都创建新多项式实际上可以预生成def precompute_polynomials(root): polynomials {} def traverse(node): if node.node_type interior: poly SecretPolynomial(node.secret, node.threshold - 1) polynomials[node] poly for child in node.children: traverse(child) traverse(root) return polynomials6.2 支持更复杂的访问策略可以扩展节点类型支持更丰富的逻辑class EnhancedAccessTreeNode(AccessTreeNode): def __init__(self, node_type, thresholdNone, attributeNone, logic_gateNone): super().__init__(node_type, threshold, attribute) self.logic_gate logic_gate # 支持 AND/OR/NAND等 def evaluate(self, attributes): if self.node_type leaf: return self.attribute in attributes child_results [child.evaluate(attributes) for child in self.children] if self.logic_gate AND: return all(child_results) elif self.logic_gate OR: return any(child_results) # 可扩展其他逻辑门6.3 可视化访问树使用graphviz库可视化访问树结构from graphviz import Digraph def visualize_tree(root): dot Digraph() def add_nodes(node): if node.node_type leaf: dot.node(str(id(node)), f属性: {node.attribute}) else: dot.node(str(id(node)), f门限: {node.threshold}/{len(node.children)}) for child in node.children: dot.edge(str(id(node)), str(id(child))) add_nodes(child) add_nodes(root) return dot7. 实际应用中的考量在真实场景中实现CP-ABE还需要考虑属性撤销机制如何处理用户属性变更或撤销性能优化特别是大规模属性集时的计算效率安全参数选择多项式系数范围、素数域大小等密钥管理如何安全分发和存储属性密钥一个实用的优化是缓存中间计算结果from functools import lru_cache class CachedAccessTreeNode(AccessTreeNode): lru_cache(maxsizeNone) def evaluate(self, attributes): # 缓存评估结果 if self.node_type leaf: return self.attribute in attributes child_results [child.evaluate(attributes) for child in self.children] return sum(child_results) self.threshold8. 完整代码架构建议对于生产级实现建议采用以下模块化结构/cp-abe-simulator │── core/ │ ├── polynomial.py # 多项式相关操作 │ ├── node.py # 访问树节点定义 │ ├── tree.py # 访问树构建与操作 │ └── crypto.py # 加密相关操作 │── utils/ │ ├── visualization.py # 树可视化 │ └── validator.py # 策略验证 └── examples/ ├── academic.py # 学院示例 └── healthcare.py # 医疗场景示例这种结构便于扩展和维护每个模块专注于单一职责。

相关文章:

实战指南:用Python模拟实现一个简易的CP-ABE访问树(附完整代码)

实战指南:用Python模拟实现一个简易的CP-ABE访问树(附完整代码) 在数据安全领域,基于属性的加密(Attribute-Based Encryption, ABE)正逐渐成为细粒度访问控制的热门技术。其中密文策略ABE(CP-AB…...

单片机控制板PCB布局布线原则——规避干扰,提升性能

问:PCB布局布线对单片机控制板的影响有多大?核心布局布线原则有哪些?答:PCB布局布线是单片机控制板设计的“灵魂”,直接决定控制板的稳定性、抗干扰能力和运行性能,甚至可能导致设计失败——同样的电路原理…...

2025届学术党必备的降重复率平台推荐榜单

Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 想要降低AIGC内容里的人造痕迹,得从好些维度去入手。第一个维度是调整句式结构&a…...

2025届最火的六大降重复率网站实测分析

Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 在人工智能辅助写作的场景当中,要去降低AI所生成的痕迹,那就得从指令…...

为什么你的Docker AI服务永远跑不满GPU?——NVIDIA DCNM+Dockerd定制调度器部署手册(限内部团队解密版)

第一章:为什么你的Docker AI服务永远跑不满GPU?——NVIDIA DCNMDockerd定制调度器部署手册(限内部团队解密版)GPU资源利用率长期低于40%?不是显存瓶颈,而是Docker原生调度器根本“看不见”GPU拓扑与NUMA亲和…...

AVM环视拼接效果总不满意?可能是鸟瞰图微调没做好(附Blender可视化调整实战)

AVM环视拼接效果优化:鸟瞰图微调与Blender可视化实战 环视监控系统(AVM)已成为现代智能汽车的标配功能,但许多工程师在完成基础拼接后常遇到一个尴尬局面——系统"能用"却不够"好用"。鸟瞰图视角生硬、拼接缝…...

2026届必备的六大降AI率方案实测分析

Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 在人工智能写作越来越普遍的情况下,降AI工具出现用于降低文本被AI检测系统识别的…...

如何在Debian系统上稳定安装宝塔面板_解决源冲突问题

...

ANSYS FLUENT新手避坑指南:从ICEM网格导入到流动传热计算的全流程实操

ANSYS FLUENT新手避坑指南:从ICEM网格导入到流动传热计算的全流程实操 第一次打开FLUENT时,面对密密麻麻的菜单和参数,大多数新手都会感到手足无措。记得我刚开始使用时,光是导入一个简单的二维网格就花了整整一天时间——不是单位…...

Golang怎么CGO交叉编译_Golang如何在交叉编译时处理CGO依赖问题【避坑】

CGO_ENABLED0不能彻底解决交叉编译问题,仅适用于完全不依赖C库的项目;启用CGO时需严格匹配目标平台工具链、头文件及库路径,否则易导致静默失败。CGO_ENABLED0 不能解决所有交叉编译问题设成 CGO_ENABLED0 确实能绕过 CGO,但代价是…...

从‘种钻石’到‘火车趣题’:用天梯赛L1真题带你玩转C语言编程思维

从‘种钻石’到‘火车趣题’:用天梯赛L1真题带你玩转C语言编程思维 编程学习最怕什么?枯燥的语法规则、机械的代码练习、脱离实际的应用场景。但当我们把每道编程题看作一个待解的谜题或生活场景的模拟时,学习过程立刻变得生动起来。天梯赛L1…...

窗口置顶工具PinWin:解决多任务窗口管理的效率瓶颈

窗口置顶工具PinWin:解决多任务窗口管理的效率瓶颈 【免费下载链接】PinWin Pin any window to be always on top of the screen 项目地址: https://gitcode.com/gh_mirrors/pin/PinWin 在Windows多任务工作环境中,窗口管理效率直接影响工作流程的…...

如何永久备份微信聊天记录:WeChatMsg完整免费工具终极指南

如何永久备份微信聊天记录:WeChatMsg完整免费工具终极指南 【免费下载链接】WeChatMsg 提取微信聊天记录,将其导出成HTML、Word、CSV文档永久保存,对聊天记录进行分析生成年度聊天报告 项目地址: https://gitcode.com/GitHub_Trending/we/W…...

DREAM框架:分布式RAG实验平台的技术解析与实践

1. DREAM框架概述:分布式RAG实验平台在构建检索增强生成(RAG)系统时,工程师们常面临一个关键挑战:如何在众多参数组合(如LLM选择、嵌入模型、检索方法等)中找到最优配置?传统单机实验…...

2025终极指南:LinkSwift网盘直链下载助手,让下载速度飞起来!

2025终极指南:LinkSwift网盘直链下载助手,让下载速度飞起来! 【免费下载链接】Online-disk-direct-link-download-assistant 一个基于 JavaScript 的网盘文件下载地址获取工具。基于【网盘直链下载助手】修改 ,支持 百度网盘 / 阿…...

D3KeyHelper完整指南:暗黑3自动化按键助手的终极解决方案

D3KeyHelper完整指南:暗黑3自动化按键助手的终极解决方案 【免费下载链接】D3keyHelper D3KeyHelper是一个有图形界面,可自定义配置的暗黑3鼠标宏工具。 项目地址: https://gitcode.com/gh_mirrors/d3/D3keyHelper 暗黑破坏神3作为一款经典的动作…...

Windows 11任务栏拖放功能修复:三分钟恢复高效工作流

Windows 11任务栏拖放功能修复:三分钟恢复高效工作流 【免费下载链接】Windows11DragAndDropToTaskbarFix "Windows 11 Drag & Drop to the Taskbar (Fix)" fixes the missing "Drag & Drop to the Taskbar" support in Windows 11. It…...

如何优雅处理SQL存储过程异常_使用TRY-CATCH块机制

TRY-CATCH只捕获运行时错误(如除零、主键冲突),不捕获编译期错误(如语法错、对象不存在);DDL语句出错可能中断批处理,CATCH来不及触发;RAISERROR需≥11级才被捕获;CATCH中…...

ElasticSearch 核心:分片策略全解析 + 分片/副本数精准配置实战

ElasticSearch 核心:分片策略全解析 分片/副本数精准配置实战一、前言二、基础概念:ES 分片与副本2.1 核心定义2.2 分片工作流程图三、ElasticSearch 分片策略全解析3.1 策略1:默认哈希路由策略(最常用)3.1.1 原理3.1…...

物联网AI MicroPython传感器实战 之 TEA5767 FM收音机模块驱动与智能场景应用

1. TEA5767 FM收音机模块初探 第一次拿到TEA5767这个小玩意儿时,我差点以为是个U盘——30mm见方的黑色模块,就比硬币大一圈。但别小看它,这可是能让你用MicroPython玩转FM广播的神器。作为一款数字调谐收音机芯片,TEA5767最大的特…...

热搜第7!《灵魂摆渡》电影竟全AI生成,影视圈要变天了?

近日,一条关于经典国产网剧《灵魂摆渡》的消息悄然爬上微博热搜第7的位置,话题标签#灵魂摆渡电影全AI生成#”瞬间引爆了舆论场。对于许多资深剧迷而言,《灵魂摆渡》不仅是一部剧集,更是一段关于灵异、温情与人生哲理的青春记忆。然…...

CCC数字钥匙车主配对【NFC】——Phase2安全通道与证书交换详解

1. CCC数字钥匙车主配对Phase2的核心价值 想象一下这样的场景:你刚买了一辆新车,掏出手机轻轻一碰车门把手,车辆就自动解锁并启动引擎。这背后最关键的技术环节,就是CCC数字钥匙的车主配对流程。而Phase2阶段,正是整个…...

告别命令行!手把手教你用Docker Compose一键部署Kafka UI(附多集群配置)

告别命令行!手把手教你用Docker Compose一键部署Kafka UI(附多集群配置) 在分布式消息系统的世界里,Kafka凭借其高吞吐、低延迟的特性成为企业级架构的核心组件。但当我们真正面对那些黑底白字的终端窗口,用命令行创建…...

别再只盯着requests了!Python爬虫进阶:用curl_cffi轻松伪装Chrome TLS指纹(附避坑指南)

Python爬虫进阶:用curl_cffi轻松伪装Chrome TLS指纹实战指南 如果你曾经用Python的requests库写过爬虫,大概率遇到过这样的场景:浏览器能正常访问的页面,用requests却返回"Just a moment"或者403错误。这很可能是因为目…...

Qt 6.5 商用项目选哪个许可证?GPL、LGPL、商业版保姆级避坑指南

Qt 6.5商用项目许可证选择全攻略:从法律风险到成本优化 当技术决策遇上法律条款,选择Qt许可证就像在迷宫中寻找最优路径。作为跨平台开发框架的标杆,Qt 6.5为商业项目提供了三种截然不同的许可证模式——GPL、LGPL和商业授权,每种…...

RWKV7-1.5B-world应用场景:中文教育APP集成——作文批改+英文翻译双功能

RWKV7-1.5B-world应用场景:中文教育APP集成——作文批改英文翻译双功能 1. 引言:轻量级双语模型的教育应用价值 在中文教育APP开发中,智能批改和双语翻译是两大核心需求。传统方案需要分别部署作文批改和翻译模型,不仅资源消耗大…...

别再只会用for循环了!用Python的combinations函数3行代码搞定组合问题

用Python的combinations函数3行代码解决复杂组合问题 在数据处理和算法设计中,组合问题无处不在。比如从10个候选人中选出3人组成项目团队,或者分析电商平台上5件商品的搭配销售可能性。传统解决方案往往需要嵌套多层for循环,不仅代码冗长难维…...

科研绘图灵感库:我是如何用MATLAB脚本建立个人Nature图表数据库的

科研绘图灵感库:用MATLAB构建可检索的Nature图表数据库 第一次在组会上展示数据时,导师皱着眉头打断我:"这个柱状图的配色太刺眼了,Nature上哪有这样用色的?"那一刻我才意识到,顶级期刊的图表美学…...

【向量搜索落地生死线】:EF Core 10中Embedding缓存穿透、维度错配、FP16截断这3类故障如何10分钟定位?

第一章:EF Core 10向量搜索扩展的架构演进与核心约束EF Core 10 向量搜索扩展并非简单叠加功能,而是对查询管道、模型元数据和提供程序抽象层的一次深度重构。其核心目标是在保持 LINQ 表达式树语义一致性的前提下,将向量相似性计算&#xff…...

Windows下用Anaconda搞定CycleGAN复现:从环境配置到训练测试的保姆级避坑指南

Windows下Anaconda环境复现CycleGAN全流程实战指南 当第一次接触CycleGAN时,我被它无需配对数据就能实现图像风格转换的能力所震撼。但随之而来的环境配置问题却让许多初学者望而却步——特别是当你的主力机是Windows系统时。本文将带你避开我踩过的所有坑&#xf…...