首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

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
  • 腾讯「腾讯云开发者社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。
  • 如有侵权,请联系 cloudcommunity@tencent.com 删除。

扫码

添加站长 进交流群

领取专属 10元无门槛券

私享最新 技术干货

扫码加入开发者社群
领券