Paillier

1paillier加密原理
https://blog.csdn.net/qq_33885461/article/details/86555560
2实现
借助https://github.com/data61/python-paillier
首先conda新建paillier虚拟环境,以下均在虚拟环境中配置

2.1安装gmpy2可以加速
sudo apt-get install libmpfr-dev libmpc-dev成功后
pip install gmpy2

2.2安装github上的那个paillier库
pip install phe
pip install “phe[cli]>1.2”
pip install “phe[cli,examples]”
进入主目录下python setup.py install

3.3实验
在python环境下
from phe import paillier
import numpy as np
public_key, private_key = paillier.generate_paillier_keypair()
A=[3.6,300,-5e-10]
enA=[public_key.encrypt(x) for x in A]
B=[3,300,-3e-10]
enB=[public_key.encrypt(x) for x in B]
en=np.add(enA,enB)
en=np.add(enA,enB)
[private_key.decrypt(x) for x in en]
输出:[6.6, 600, -8e-10]
(证明了加法同态)

你可能感兴趣的:(python,安全,机器学习)