| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 网络协议 -> charm-crypto 介绍 -> 正文阅读 |
|
[网络协议]charm-crypto 介绍 |
charm的github位置 JHUISI/charm: Charm: A Framework for Rapidly Prototyping Cryptosystems 简单介绍这是在github上的介绍。 因为提供python接口,charm可以很方便地实现各种密码算法,尤其是复现论文中提出的相关算法。当然比较经典的算法它的schemes中也集成了。 安装JHUISI/charm: Charm: A Framework for Rapidly Prototyping Cryptosystems 本地环境:Ubuntu18 + Python 3.6.9 使用官方文档 Charm-Crypto Docs! — Charm-Crypto 0.50 documentation schemesschemes
以代理重加密的部分算法为例。如下图,pre_afgh06,pre是代理重加密,afgh是算法缩写(发明人的首字母合在一起),06是2006年。pre_bss98是1998年的。 paircharm的pair是基于PBC库的。具体的使用因为我对密码也不是特别了解,便不再班门弄斧。但对于较新的算法,可以参考经典的算法,依葫芦画瓢大致也能写出。 这里补充一些可能用到的函数。PairingGroup类可以进行序列化,这样方便存储。
运行结果如下 对称加密在编写算法时,经常要利用椭圆曲线上的点生成数据密钥。而我们常用的crypto库提供的对称加密算法都是利用bytes类型作为密钥,这样就极不方便。
运行结果如下
charm/symcrypto.py at dev · JHUISI/charm Shin Y, Koo D, Yun J, et al. Decentralized server-aided encryption for secure deduplication in cloud storage[J]. IEEE Transactions on Services Computing, 2017. 哈希 hash同样以上篇论文为例,在其中一个步骤中,涉及到将文件转换为pair类型。可以看到
h
=
H
(
F
)
h = H(F)
h=H(F),
F
F
F就是file,
H
H
H就是hash,可以看到
M
1
=
g
r
1
h
M_1 = g^{r_1}h
M1?=gr1?h,
h
h
h要想在这之中计算,不得不转换为相同的类型。而接下来我们就是解决这个问题。
|
|
网络协议 最新文章 |
使用Easyswoole 搭建简单的Websoket服务 |
常见的数据通信方式有哪些? |
Openssl 1024bit RSA算法---公私钥获取和处 |
HTTPS协议的密钥交换流程 |
《小白WEB安全入门》03. 漏洞篇 |
HttpRunner4.x 安装与使用 |
2021-07-04 |
手写RPC学习笔记 |
K8S高可用版本部署 |
mySQL计算IP地址范围 |
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 | -2025/1/9 1:37:38- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |