在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 相关文章推荐
pycharm 使用心得(九)解决No Python interpreter selected的问题
Jun 06 Python
python 性能提升的几种方法
Jul 15 Python
python+selenium+autoit实现文件上传功能
Aug 23 Python
python中virtualenvwrapper安装与使用
May 20 Python
Python实现重建二叉树的三种方法详解
Jun 23 Python
python 2.7.13 安装配置方法图文教程
Sep 18 Python
通过python的matplotlib包将Tensorflow数据进行可视化的方法
Jan 09 Python
python中的句柄操作的方法示例
Jun 20 Python
使用tqdm显示Python代码执行进度功能
Dec 08 Python
Python如何优雅删除字符列表空字符及None元素
Jun 25 Python
python 自动刷新网页的两种方法
Apr 20 Python
Pygame Time时间控制的具体使用详解
Nov 17 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
在windows iis5下安装php4.0+mysql之我见
2006/10/09 PHP
PHP 命令行工具 shell_exec, exec, passthru, system详细使用介绍
2011/09/11 PHP
JS对外部文件的加载及对IFRMAME的加载的实现,当加载完成后,指定指向方法(方法回调)
2011/07/04 Javascript
javascript密码强度校验代码(两种方法)
2015/08/10 Javascript
使用jQuery加载html页面到指定的div实现方法
2016/07/13 Javascript
AngularJS中的表单简单入门
2016/07/28 Javascript
Jquery组件easyUi实现选项卡切换示例
2016/08/23 Javascript
H5移动端图片压缩上传开发流程
2016/11/09 Javascript
基于Javascript倒计时效果
2016/12/22 Javascript
关于jQuery里prev()的简单操作代码
2017/10/27 jQuery
JS中Object对象的原型概念基础
2018/01/29 Javascript
使用validate.js实现表单数据提交前的验证方法
2018/09/04 Javascript
JS中appendChild追加子节点无效的解决方法
2018/10/14 Javascript
webpack4手动搭建Vue开发环境实现todoList项目的方法
2019/05/16 Javascript
Vue.js实现备忘录功能
2019/06/26 Javascript
JS设置自定义快捷键并实现图片上下左右移动
2019/10/17 Javascript
vue实现移动端项目多行文本溢出省略
2020/07/29 Javascript
一篇文章带你从零快速上手Rollup
2020/09/07 Javascript
[01:51]2018年度CS GO最具人气外援-完美盛典
2018/12/16 DOTA
一个简单的python程序实例(通讯录)
2013/11/29 Python
python任务调度实例分析
2015/05/19 Python
python爬取王者荣耀全皮肤的简单实现代码
2020/01/31 Python
python GUI库图形界面开发之PyQt5信号与槽机制、自定义信号基础介绍
2020/02/25 Python
在jupyter notebook中调用.ipynb文件方式
2020/04/14 Python
Win10用vscode打开anaconda环境中的python出错问题的解决
2020/05/25 Python
Keras 实现加载预训练模型并冻结网络的层
2020/06/15 Python
python程序实现BTC(比特币)挖矿的完整代码
2021/01/20 Python
css3 media 响应式布局的简单实例
2016/08/03 HTML / CSS
英国领先的电视购物零售商:Ideal World
2019/03/18 全球购物
普通大学毕业生自荐信
2013/11/04 职场文书
学生会干部自荐信
2014/02/04 职场文书
学生安全教育材料
2014/02/14 职场文书
党务公开方案
2014/05/06 职场文书
2014年员工工作总结范文
2014/11/18 职场文书
2014个人年终工作总结范文
2014/12/15 职场文书
花木兰观后感
2015/06/10 职场文书