在Python中使用M2Crypto模块实现AES加密的教程


Posted in Python onApril 08, 2015

 AES(英文:Advanced Encryption Standard,中文:高级加密标准),是一种区块加密标准。AES将原始数据分成多个4×4字节矩阵来处理,通过预先定义的密钥对每个字节矩阵中的每个字节进行异或、替换、移位以及线性变换操作来达到加密的目的。密钥长度可以是128,192或256比特。
    下面是一个利用Python M2Crypto库,并使用aes_128_ecb算法进行加密和解密的例子。首先介绍一下几个关键的点:
1、iv(Initialization vector),即初始化向量,用于避免相同的数据多次加密都产生相同的密文。最大长度为16字节,超出16字节部分会被忽略,最好是随机产生以增加加密的强度。
2、ECB (Electronic codebook,ECB),它会对每个4×4字节矩阵都用同一个密钥进行加密,而且?]有使用 IV。优点是每个字节矩阵都可以独立进行加密,因此可以同时对每个字节矩阵进行加密;缺点是对于相关的数据,加密之后的密文都是一样的。
3、Padding,由于AES是以4×4字节矩阵作为单位进行处理,因为待加密数据必须是16的倍数,若不足16的倍数,将会进行填充操作。aes_128_ecb算法加密默认填充模式是pkcs5。
 

from M2Crypto.EVP import Cipher 
from M2Crypto import m2 
from M2Crypto import util 
  
ENCRYPT_OP = 1 # 加密操作 
DECRYPT_OP = 0 # 解密操作 
  
iv = '\0' * 16 # 初始化变量,对于aes_128_ecb算法无用 
PRIVATE_KEY = 'dd7fd4a156d28bade96f816db1d18609' # 密钥 
  
def Encrypt(data): 
 '使用aes_128_ecb算法对数据加密' 
 cipher = Cipher(alg = 'aes_128_ecb', key = PRIVATE_KEY, iv = iv, op = ENCRYPT_OP) 
 buf = cipher.update(data) 
 buf = buf + cipher.final() 
 del cipher 
 # 将明文从字节流转为16进制 
 output = '' 
 for i in buf: 
  output += '%02X' % (ord(i)) 
 return output 
  
def Decrypt(data): 
 '使用aes_128_ecb算法对数据解密' 
 # 将密文从16进制转为字节流 
 data = util.h2b(data) 
 cipher = Cipher(alg = 'aes_128_ecb', key = PRIVATE_KEY, iv = iv, op = DECRYPT_OP) 
 buf = cipher.update(data) 
 buf = buf + cipher.final() 
 del cipher 
 return buf
Python 相关文章推荐
Python守护进程(daemon)代码实例
Mar 06 Python
Python去除列表中重复元素的方法
Mar 20 Python
Python构建XML树结构的方法示例
Jun 30 Python
Python中使用haystack实现django全文检索搜索引擎功能
Aug 26 Python
python实现装饰器、描述符
Feb 28 Python
Python数据集切分实例
Dec 08 Python
python交易记录链的实现过程详解
Jul 03 Python
给我一面国旗 python帮你实现
Sep 30 Python
python web框架Flask实现图形验证码及验证码的动态刷新实例
Oct 14 Python
Python线程条件变量Condition原理解析
Jan 20 Python
python中封包建立过程实例
Feb 18 Python
详解使用scrapy进行模拟登陆三种方式
Feb 21 Python
Python使用scrapy采集时伪装成HTTP/1.1的方法
Apr 08 #Python
Python打印scrapy蜘蛛抓取树结构的方法
Apr 08 #Python
使用IPython来操作Docker容器的入门指引
Apr 08 #Python
仅用50行Python代码实现一个简单的代理服务器
Apr 08 #Python
用Python实现一个简单的能够发送带附件的邮件程序的教程
Apr 08 #Python
Python 创建子进程模块subprocess详解
Apr 08 #Python
Python中使用gzip模块压缩文件的简单教程
Apr 08 #Python
You might like
PHP生成指定长度随机数最简洁的方法
2014/07/14 PHP
php微信公众平台开发之获取用户基本信息
2015/08/17 PHP
JTrackBar水平拖动效果
2007/07/15 Javascript
XML的代替者----JSON
2007/07/21 Javascript
JavaScript 继承的实现
2009/07/09 Javascript
js控制div及网页相关属性的代码
2009/12/19 Javascript
从QQ网站中提取的纯JS省市区三级联动菜单
2013/12/25 Javascript
ajax提交表单实现网页无刷新注册示例
2014/05/08 Javascript
快速解决jquery.touchSwipe左右滑动和垂直滚动条冲突
2016/04/15 Javascript
JavaScript实现九九乘法表的简单实例
2016/06/07 Javascript
JavaScript学习小结之使用canvas画“哆啦A梦”时钟
2016/07/24 Javascript
JavaScript实现获取用户单击body中所有A标签内容的方法
2017/06/05 Javascript
addeventlistener监听scroll跟touch(实例讲解)
2017/08/04 Javascript
js排序与重组的实例讲解
2017/08/28 Javascript
VUE中的无限循环代码解析
2017/09/22 Javascript
使用vuex较为优雅的实现一个购物车功能的示例代码
2019/12/09 Javascript
JavaScript 链表定义与使用方法示例
2020/04/28 Javascript
[01:05:59]Mineski vs Secret 2019国际邀请赛淘汰赛 败者组 BO3 第二场 8.22
2019/09/05 DOTA
用Python的线程来解决生产者消费问题的示例
2015/04/02 Python
dataframe 按条件替换某一列中的值方法
2019/01/29 Python
解决pycharm下os.system执行命令返回有中文乱码的问题
2019/07/07 Python
Python使用正则表达式分割字符串的实现方法
2019/07/16 Python
python使用flask与js进行前后台交互的例子
2019/07/19 Python
python实现超市商品销售管理系统
2019/10/25 Python
Python 解决火狐浏览器不弹出下载框直接下载的问题
2020/03/09 Python
Python word文本自动化操作实现方法解析
2020/11/05 Python
pytorch 把图片数据转化成tensor的操作
2021/03/04 Python
料理师求职信
2014/01/30 职场文书
绿化工程实施方案
2014/03/17 职场文书
应届硕士毕业生自荐信
2014/05/26 职场文书
工程部经理岗位职责
2015/02/02 职场文书
公司行政主管岗位职责
2015/04/09 职场文书
Python基础之教你怎么在M1系统上使用pandas
2021/05/08 Python
简单聊聊Vue中的计算属性和属性侦听
2021/10/05 Vue.js
python机器学习实现oneR算法(以鸢尾data为例)
2022/03/03 Python
Ruby处理YAML和json数据
2022/04/18 Ruby