python加密解密算法_Python实现Paillier加密解密算法 - B3ale

本文介绍了Paillier加密系统,这是一种1999年发明的概率公钥加密算法,基于复合剩余类的困难问题。文章详细阐述了算法的Keygen、Encipher和Decipher过程,并提供了一个使用gmpy2和libnum库实现的Python代码示例。
摘要由CSDN通过智能技术生成

Paillier 加密系统,是 1999 年 Paillier 发明的概率公钥加密系统。基于复合剩余类的困难问题。该加密算法是一种同态加密,满足加法和数乘同态。

Introduction

Keygen

首先选择两个大素数 $p$ 和 $q$,计算出 $n$ 为 $p$ 和 $q$ 的乘积。并取一个随机数 $g$(通常取 $n+1$)。$n$ 和 $g$ 作为公钥。

然后根据卡迈克尔函数计算私钥 $\lambda$ 为 $p-1$ 和 $q-1$ 的乘积。

Encipher

加密时取一个随机数 $r$,计算出 $c \equiv g^m r^n(mod\ n^2)$。

Decipher

解密有一点复杂。首先我们可以得到:

$$

c^\lambda \equiv (g^m r^n)^\lambda \equiv g^{m \lambda} r^{n \lambda}(mod\ n^2)

$$

根据卡迈克尔函数,即对于任何 $\omega \in Z^*_{n^2}$,必定存在以下结论:

$$

\omega^{n \lambda} \equiv 1(mod\ n^2)

$$

那么可以得到 $c^\lambda \equiv g^{m \lambda}(mod\ n^2)$。

然后看看生成元 $g$,实际上是通过 $g=(1+\alpha n)\beta^n$ 得到的,并且 $\alpha,\beta \in Z^*_n$。由此可得:

$$

c^\lambda \equiv (1+\alpha n)^{m \lambda}\beta^{n m \lambda} \equiv (1+\alpha n)^{m \lambda}(mod\ n^2)

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值