在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实现单词翻译功能
Jun 06 Python
100行python代码实现跳一跳辅助程序
Jan 15 Python
Tensorflow使用tfrecord输入数据格式
Jun 19 Python
Python 实现取矩阵的部分列,保存为一个新的矩阵方法
Nov 14 Python
对python列表里的字典元素去重方法详解
Jan 21 Python
python图像和办公文档处理总结
May 28 Python
PyQt5实现暗黑风格的计时器
Jul 29 Python
TensorFlow基于MNIST数据集实现车牌识别(初步演示版)
Aug 05 Python
浅谈python之自动化运维(Paramiko)
Jan 31 Python
python默认参数调用方法解析
Feb 09 Python
Django如何使用redis作为缓存
May 21 Python
Python Unittest原理及基本使用方法
Nov 06 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
《五等分的花嫁》漫画完结!2020年10月第2期TV动画制作组换血!
2020/03/06 日漫
十天学会php之第八天
2006/10/09 PHP
搜索引擎技术核心揭密
2006/10/09 PHP
SMARTY学习手记
2007/01/04 PHP
浅谈使用 PHP 进行手机 APP 开发(API 接口开发)
2014/08/11 PHP
如何使用GDB调试PHP程序
2015/12/08 PHP
[原创]smarty简单模板变量输出方法
2016/07/09 PHP
PHP PDOStatement::fetchObject讲解
2019/02/01 PHP
JS去掉第一个字符和最后一个字符的实现代码
2014/02/20 Javascript
jquery中map函数遍历数组用法实例
2015/05/18 Javascript
javascript中数组方法汇总
2015/07/07 Javascript
jQuery中iframe的操作(点击按钮新增窗口)
2016/04/20 Javascript
jQuery获取file控件中图片的宽高与大小
2016/08/04 Javascript
js实现打地鼠小游戏
2017/02/13 Javascript
利用angularjs1.4制作的简易滑动门效果
2017/02/28 Javascript
基于jQuery和CSS3实现APPLE TV海报视差效果
2017/06/16 jQuery
JavaScript中立即执行函数实例详解
2017/11/04 Javascript
nodejs使用express获取get和post传值及session验证的方法
2017/11/09 NodeJs
vue项目中跳转到外部链接的实例讲解
2018/09/20 Javascript
微信小程序自定义菜单切换栏tabbar组件代码实例
2019/12/30 Javascript
element-ui和vue表单(对话框)验证提示语(残留)清除操作
2020/09/11 Javascript
electron踩坑之remote of undefined的解决
2020/10/06 Javascript
matplotlib设置legend图例代码示例
2017/12/19 Python
Python 实现淘宝秒杀的示例代码
2018/01/02 Python
python使用turtle库与random库绘制雪花
2018/06/22 Python
在Pycharm中将pyinstaller加入External Tools的方法
2019/01/16 Python
用Python在Excel里画出蒙娜丽莎的方法示例
2020/04/28 Python
详解pandas apply 并行处理的几种方法
2021/02/24 Python
中文专业毕业生自荐信
2013/10/28 职场文书
网络工程师专家职业发展路线
2014/02/14 职场文书
《我的第一本书》教学反思
2014/02/15 职场文书
大学生创业项目方案
2014/03/08 职场文书
企业精细化管理实施方案
2014/03/23 职场文书
网站美工岗位职责
2014/04/02 职场文书
升国旗演讲稿
2014/09/05 职场文书
2014年科室工作总结范文
2014/12/19 职场文书