1.Charm-crypto官方网站:http://charm-crypto.io/python
2.Release版本下载地址:https://github.com/JHUISI/charm/releasesgit
安装步骤以下github
1.下载Windows_Release安装程序Charm-Crypto-0.43.ex算法
2.安装有Python3.7和python2.7
其中python2.7未添加环境变量,给出以下提示ubuntu
编号(01)Python version(s)3.3/2.7 not found, the installation will now abort.
Python 版本3.3或者2.7未找到,本安装程序将会终止
服务器
尝试将Python2.7 添加进入环境变量
在系统变量Path
中添加D:\python27
依然的获得编号为01的错误;python2.7
尝试重启之后问题依然存在测试
在GoogleGroups上的相关安装信息、flex
1.均认为没法彻底在Windows环境上运行Charm-Crypto: https://groups.google.com/forum/#!topic/charm-crypto/ybDr75OemJ8网站
2.指出在Linux环境下的Charm-Crypto安装方法: https://groups.google.com/forum/#!topic/charm-crypto/0-kgAHfiGmo
1.Ubuntu的使用版本
使用Ubuntu 18.04.2 LTS 版本进行开发。链接地址:https://cn.ubuntu.com/download
2.安装部分
sudo apt-get install subversion sudo apt-get install m4 sudo apt-get install flex sudo apt-get install bison sudo apt-get install libssl-dev sudo apt-get python3-setuptools python3-dev sudo apt-get libgmp-dev wget http://crypto.stanford.edu/pbc/files/pbc-0.5.14.tar.gz tar xf pbc-0.5.14.tar.gz cd pbc-0.5.14 ./configure && make && sudo make install
从https://pypi.python.org/pypi/charm-crypto/0.43下载Charm-Crypto安装包,安装包Charm-Crypto-0.43.tar.gz)(364.5 kB)
命令行安装命令
./configure.sh sudo make sudo make install 建议使用make test进行测试 sudo ldconfig
可能遇到的问题
1.Openssl不兼容的问题
Chrm-Crypto基于Openssl 1.0左右版本(没法在1.1.X版本下构建)
2.关于如何更改Openssl版本
查看现有版本
/usr/bin/openssl version OpenSSL 1.0.1f 6 Jan 2014下载并解压
wget https://www.openssl.org/source/openssl-1.0.2l.tar.gz tar -xzvf openssl-1.0.2l.tar.gz编译安装
cd openssl-1.0.2l sudo ./config sudo make install创建新版链接
sudo ln -sf /usr/local/ssl/bin/openssl `which openssl`查看新版本
/usr/bin/openssl version OpenSSL 1.0.2l 25 May 2017
若是make依然不成功,可尝试
apt-get install libssl1.0-dev
1.什么是GMP?
GMP全称GNU Multiple Precision Arithmetic Library, 即GNU高精度算术运算库。它是一个开源的高精度运算库,其中不但有普通的整数、实数、浮点数的高精度运算,还有随机数生成,尤为是提供了很是完备的数论中的运算接口,好比Miller-Rabin素数测试算法、大素数生成、欧几里德算法、求域中元素的逆、Jacobi符号、legendre符号等[来源]
2.什么是Subversion?
Subversion是一个自由开源的版本控制系统。在Subversion管理下,文件和目录能够超越时空。Subversion将文件存放在中心版本库里,这个版本库很像一个普通的文件服务器,不一样的是,它能够记录每一次文件和目录的修改状况,这样就能够借此将数据恢复到之前的版本,并能够查看数据的更改细节。正由于如此,许多人将版本控制系统看成一种神奇的“时间机器”。
3.什么是PBC?
python3环境下的PBC库,可用于双线性配对计算的使用