在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实现多行注释的另类方法
Aug 22 Python
python实现在无须过多援引的情况下创建字典的方法
Sep 25 Python
python实现同时给多个变量赋值的方法
Apr 30 Python
Python3中的2to3转换工具使用示例
Jun 12 Python
Python中属性和描述符的正确使用
Aug 23 Python
对python生成业务报表的实例详解
Feb 03 Python
使用python实现kNN分类算法
Oct 16 Python
python 变量初始化空列表的例子
Nov 28 Python
PyQt5实现仿QQ贴边隐藏功能的实例代码
May 24 Python
Python读取多列数据以及用matplotlib制作图表方法实例
Sep 23 Python
python 删除系统中的文件(按时间,大小,扩展名)
Nov 19 Python
python opencv图像处理(素描、怀旧、光照、流年、滤镜 原理及实现)
Dec 10 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中flush()、ob_flush()、ob_end_flush()的区别介绍
2013/02/17 PHP
ThinkPHP使用getlist方法实现数据搜索功能示例
2017/05/08 PHP
判断对象是否Window的实现代码
2012/01/10 Javascript
JavaScript高级程序设计(第3版)学习笔记12 js正则表达式
2012/10/11 Javascript
Jquery each方法跳出循环,并获取返回值(实例讲解)
2013/12/12 Javascript
解决用jquery load加载页面到div时,不执行页面js的问题
2014/02/22 Javascript
jquery获取一个元素下面相同子元素的个数代码
2014/07/31 Javascript
七夕情人节丘比特射箭小游戏
2015/08/20 Javascript
百度地图给map添加右键菜单(判断是否为marker)
2016/03/04 Javascript
快速解决js动态改变dom元素属性后页面及时渲染的问题
2016/07/06 Javascript
AngularJS 路由详解和简单实例
2016/07/28 Javascript
webuploader模态框ueditor显示问题解决方法
2016/12/27 Javascript
vue项目打包后打开页面空白解决办法
2018/06/29 Javascript
vue系列之requireJs中引入vue-router的方法
2018/07/18 Javascript
Angular5集成eventbus的示例代码
2018/07/19 Javascript
Vue源码之关于vm.$delete()/Vue.use()内部原理详解
2019/05/01 Javascript
从源码解析Python的Flask框架中request对象的用法
2016/06/02 Python
Python正则表达式实现简易计算器功能示例
2019/05/07 Python
pytorch 状态字典:state_dict使用详解
2020/01/17 Python
Python如何操作docker redis过程解析
2020/08/10 Python
HTML5中视频音频的使用详解
2017/07/07 HTML / CSS
台湾母婴用品购物网站:Infant婴之房
2018/06/15 全球购物
SNIDEL官网:日本VIVI杂志人气少女第一品牌
2020/03/12 全球购物
新媒传信软件测试面试题
2013/02/24 面试题
科室工作的个人自我评价
2013/10/30 职场文书
行政管理人员精品工作推荐信
2013/11/04 职场文书
护士岗前培训自我评鉴
2014/02/28 职场文书
活动总结报告格式
2014/05/09 职场文书
全国法院系统开展党的群众路线教育实践活动综述(全文)
2014/10/25 职场文书
2014年少先队工作总结
2014/12/03 职场文书
委托书格式要求
2015/01/28 职场文书
逃课检讨书范文
2015/05/06 职场文书
Apache Calcite 实现方言转换的代码
2021/04/24 Servers
Python趣味实战之手把手教你实现举牌小人生成器
2021/06/07 Python
灵能百分百第三季什么时候来?
2022/03/15 日漫
Dubbo+zookeeper搭配分布式服务的过程详解
2022/04/03 Java/Android