使用Python进行AES加密和解密的示例代码


Posted in Python onFebruary 02, 2018

高级加密标准(英语:Advanced Encryption Standard,缩写:AES),在密码学中又称Rijndael加密法,是美国联邦政府采用的一种区块加密标准。这个标准用来替代原先的DES,已经被多方分析且广为全世界所使用。经过五年的甄选流程,高级加密标准由美国国家标准与技术研究院(NIST)于2001年11月26日发布于FIPS PUB 197,并在2002年5月26日成为有效的标准。2006年,高级加密标准已然成为对称密钥加密中最流行的算法之一。---百度百科

本科的时候弄过DES加密算法加密计算机文件,而DES加密算法现在基本处于被废弃的状态,所以现在想试试更高级一点的。
DES加密算法可发展为3DES加密算法,后来又被升级为AES加密算法,加长了密钥长度,也就增加了暴力破解的难度。
本次使用Python进行AES的加密解密,在ubuntu下进行:

如果没有安装Python,请先安装Python和pip:

#sudo apt-get install python
#sudo apt-get install python-pip

顺便安装两个库(有可能不叫库,一个是关于加密解密算法的,另外一个是关于字符转换的):

#pip install Ctypto
#pip install binascii

AES拥有很多模式,而此次采用的CBC模式:通过密钥和salt(起扰乱作用)按固定算法(md5)产生key和iv。然后用key和iv(初始向量,加密第一块明文)加密(明文)和解密(密文)。

下面代码实现的思想:将加密文本处理以8*16位 这样的单位进行加密,每16个字节长度的数据加密成16个字节长度的密文。在下面代码中,为简化代码,密钥所生成的key和iv都用16位的密钥代替,实际上其实可以不一样,但位数能不能不一样我就没试了。

我在参考博客的代码中做了一些修改,原来的代码在需要明文为16的倍数的时候会多生成16位的空字节,有点小问题,修改之后就没问题了。

#coding: utf8 
import sys 
from Crypto.Cipher import AES 
from binascii import b2a_hex, a2b_hex 
  
class prpcrypt(): 
  def __init__(self, key): 
    self.key = key 
    self.mode = AES.MODE_CBC 
    
  #加密函数,如果text不是16的倍数【加密文本text必须为16的倍数!】,那就补足为16的倍数 
  def encrypt(self, text): 
    cryptor = AES.new(self.key, self.mode, self.key) 
    #这里密钥key 长度必须为16(AES-128)、24(AES-192)、或32(AES-256)Bytes 长度.目前AES-128足够用 
    length = 16 
    count = len(text) 
  if(count % length != 0) : 
      add = length - (count % length) 
  else: 
    add = 0 
    text = text + ('\0' * add) 
    self.ciphertext = cryptor.encrypt(text) 
    #因为AES加密时候得到的字符串不一定是ascii字符集的,输出到终端或者保存时候可能存在问题 
    #所以这里统一把加密后的字符串转化为16进制字符串 
    return b2a_hex(self.ciphertext) 
    
  #解密后,去掉补足的空格用strip() 去掉 
  def decrypt(self, text): 
    cryptor = AES.new(self.key, self.mode, self.key) 
    plain_text = cryptor.decrypt(a2b_hex(text)) 
    return plain_text.rstrip('\0') 
  
if __name__ == '__main__': 
  pc = prpcrypt('keyskeyskeyskeys')   #初始化密钥 
  e = pc.encrypt("0123456789ABCDEF") 
  d = pc.decrypt(e)            
  print e, d 
  e = pc.encrypt("00000000000000000000000000") 
  d = pc.decrypt(e)          
  print e, d

运行结果如下:

367b61b333c242a4253cfacfe6ea709f         0123456789ABCDEF
2c1969f213c703ebedc36f9e7e5a2b88922ac938c983201c200da51073d00b2c        00000000000000000000000000

此代码中,初始密钥为keyskeyskeyskeys,可理解为加密的钥匙,只有通过这个密钥才能将已经加密后的数据解密出来。
从结果可以看出,通过AES加密,我们将‘0123456789ABCDEF'的字符串加密为0x367b61b333c242a4253cfacfe6ea709f.
将00000000000000000000000000这串字符串加密为0x2c1969f213c703ebedc36f9e7e5a2b88922ac938c983201c200da51073d00b2c,仔细观察,发现是上面的两倍,
因为原字符串的长度超过了16,但少于32,故在上面的算法中将其补齐成32个长度的字符串后再进行加密。

由此,可延伸至大文件的加密思想:逐步读取16个长度的数据,每16个长度的数据加密一次并写入加密文件,直至所有明文数据被加密完。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python模拟enum枚举类型的方法小结
Apr 30 Python
Python request设置HTTPS代理代码解析
Feb 12 Python
Python使用random.shuffle()打乱列表顺序的方法
Nov 08 Python
详解如何用TensorFlow训练和识别/分类自定义图片
Aug 05 Python
python3.6、opencv安装环境搭建过程(图文教程)
Nov 05 Python
你应该知道的Python3.6、3.7、3.8新特性小结
May 12 Python
Python Django搭建网站流程图解
Jun 13 Python
Python pymsql模块的使用
Sep 07 Python
运行python提示no module named sklearn的解决方法
Nov 29 Python
python爬虫实现爬取同一个网站的多页数据的实例讲解
Jan 18 Python
方法汇总:Python 安装第三方库常用
Apr 26 Python
利用Python脚本写端口扫描器socket,python-nmap
Jul 23 Python
为什么选择python编程语言入门黑客攻防 给你几个理由!
Feb 02 #Python
Python无损音乐搜索引擎实现代码
Feb 02 #Python
Python面向对象class类属性及子类用法分析
Feb 02 #Python
Python网络编程之TCP与UDP协议套接字用法示例
Feb 02 #Python
Python星号*与**用法分析
Feb 02 #Python
Python模块WSGI使用详解
Feb 02 #Python
Python常见字符串操作函数小结【split()、join()、strip()】
Feb 02 #Python
You might like
thinkphp 一个页面使用2次分页的实现方法
2013/07/15 PHP
PHP实现抓取HTTPS内容
2014/12/01 PHP
php中实现进程锁与多进程的方法
2016/09/18 PHP
php实现微信模拟登陆、获取用户列表及群发消息功能示例
2017/06/28 PHP
php命名空间设计思想、用法与缺点分析
2019/07/17 PHP
TP5框架请求响应参数实例分析
2019/10/17 PHP
js表数据排序 sort table data
2009/02/18 Javascript
jquery中$(#form :input)与$(#form input)的区别
2014/08/18 Javascript
JavaScript实现将数组中所有元素连接成一个字符串的方法
2015/04/06 Javascript
JavaScript中的lastIndexOf()方法使用详解
2015/06/06 Javascript
js实现向右横向滑出的二级菜单效果
2015/08/27 Javascript
AngularJS实现元素显示和隐藏的几个案例
2015/12/09 Javascript
基于JS实现横线提示输入验证码随验证码输入消失(js验证码的实现)
2016/10/27 Javascript
Extjs gridpanel 中的checkbox(复选框)根据某行的条件不能选中的解决方法
2017/02/17 Javascript
JS实现简易刻度时钟示例代码
2017/03/11 Javascript
layer弹出层取消遮罩的方法
2019/09/25 Javascript
Vue+Node实现的商城用户管理功能示例
2019/12/23 Javascript
[01:03]悬念揭晓 11月26日DOTA2完美盛典不见不散
2017/11/23 DOTA
详细讲解Python中的文件I/O操作
2015/05/24 Python
浅谈pandas中Dataframe的查询方法([], loc, iloc, at, iat, ix)
2018/04/10 Python
NLTK 3.2.4 环境搭建教程
2018/09/19 Python
Python 普通最小二乘法(OLS)进行多项式拟合的方法
2018/12/29 Python
pandas DataFrame 交集并集补集的实现
2019/06/24 Python
Django使用list对单个或者多个字段求values值实例
2020/03/31 Python
很酷的HTML5电子书翻页动画特效
2016/02/25 HTML / CSS
Spongelle官网:美国的创意护肤洗护品牌
2019/05/15 全球购物
关键字final的用法
2013/10/02 面试题
Prototype如何实现页面局部定时刷新
2013/08/06 面试题
应届生文秘专业个人自荐信格式
2013/09/21 职场文书
经济学博士求职自荐信范文
2013/11/23 职场文书
计算机专业毕业生自我鉴定
2014/01/16 职场文书
简单的辞职信范文
2014/01/18 职场文书
关于青春的演讲稿800字
2014/08/22 职场文书
团代会开幕词
2015/01/28 职场文书
MySQL query_cache_type 参数与使用详解
2021/07/01 MySQL
win11无法登录onedrive错误代码0x8004def7怎么办 ?
2022/04/05 数码科技