椭圆加解密算法

本文介绍了使用Python实现的椭圆曲线加密算法,包括加法、乘法和逆元计算等核心函数,提供了示例运行结果,可用于理解椭圆曲线密码学的基础操作。
摘要由CSDN通过智能技术生成

GitHub项目地址
算法参数如下(同比特币系统):

# 比特币系统选用的secp256k1的参数
p = 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFEFFFFFC2F
a = 0
b = 7
G = [0x79BE667EF9DCBBAC55A06295CE870B07029BFCDB2DCE28D959F2815B16F81798,
     0x483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8]
n = 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFEBAAEDCE6AF48A03BBFD25E8CD0364141
h = 1

1 文件目录如下:

.idea
add.py
demo.py
inverse_element.py
multiply.py
readme.md
sub.py
__pycache__

运行demo.py即可得到示例运行结果。

2 各文件及其内部函数说明如下:

demo.py:

​ 主程序。

add.py:

​ def add(P, Q):椭圆曲线上的有理点的加法,return P+Q

inverse_element.py:

​ def inverse_element(e, φ _ n φ\_n φ_n):计算e在mod φ _ n φ\_n φ_n意义下的逆元素

multiply.py:

​ def multiply(k, G):椭圆曲线上的有理点的乘法,return k*G

sub.py:

​ def sub(P, Q):解密时需要用到的减法。

3 示例运行结果

明文对应的点: [15413331901059811907208139813032614876243219691325873248599010147666926890190, 71750865056742194365132932217611284235480354413947246251465263395034040340620]
解密得到的明文对应的点: [15413331901059811907208139813032614876243219691325873248599010147666926890190, 71750865056742194365132932217611284235480354413947246251465263395034040340620]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值