最近需要通过网络加密传输一些文件,首先想到的是RSA,公钥 + 私钥的搭配,不能再好。
2. 导入模块,创建密钥对。
3. 然后用公钥加密,用私钥解密。
运行结果如下
4. 如果只是简单的,小字符串的加密,到这里就已经完完成了,那么如果字符串长一些呢?
这里把message的长度增加了10倍,结果报错提示最大空间只有 117。
5. 对于大文件加密,rsa以前提供了一种 bigfile 方法,将大文件分割成小块进行加密,因为在效率和加密后文件大小上没有优势,现在已不推荐使用。
可以看出,IDE也给我了不建议使用的提示。
官方文档同样给出了警告提醒,并推荐使用 RSA + AES 的方式。
6. Python AES加密,需要安装pycrypto模块(https://pypi.python.org/pypi/pycrypto),这个模块在大部分Linux上自带,在Windows上就没有那么好安装了。这里提供一个exe安装包的传送门(http://www.voidspace.org.uk/python/modules.shtml#pycrypto)。
7. AES加密字符串的长度必须要是16/24/32的倍数,否则需要进行补位。
运行结果如下
这里采用了CBC模式,key为密钥,iv为盐值,ECB和CTR模式不支持iv。
8. 我们再封装两个RSA的函数,用来联合加密。
9. 随机生成AES加密需要的 key 和 iv 。
10.将 key 和 iv 进行RSA加密,message采用AES加密,然后将两条信息合并起来进行数据传输。
11. 运行结果如下。
领取专属 10元无门槛券
私享最新 技术干货