Python优雅的加密传输文件

最近需要通过网络加密传输一些文件,首先想到的是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. 运行结果如下。

  • 发表于:
  • 原文链接:http://kuaibao.qq.com/s/20180118G0PEV900?refer=cp_1026

相关快讯

扫码关注云+社区