在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中基本的日期时间处理的学习教程
Oct 16 Python
python3实现UDP协议的服务器和客户端
Jun 14 Python
Python subprocess模块功能与常见用法实例详解
Jun 28 Python
python3基于TCP实现CS架构文件传输
Jul 28 Python
Django框架模板注入操作示例【变量传递到模板】
Dec 19 Python
python通过实例讲解反射机制
Oct 17 Python
python redis 批量设置过期key过程解析
Nov 26 Python
Python递归及尾递归优化操作实例分析
Feb 01 Python
使用python3 实现插入数据到mysql
Mar 02 Python
python画图常规设置方式
Mar 05 Python
Python jieba结巴分词原理及用法解析
Nov 05 Python
用python制作个音乐下载器
Jan 30 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
[EPIC] Larva vs Flash ZvT @ Crossing Field [2017-10-09]
2020/03/17 星际争霸
PHP从FLV文件获取视频预览图的方法
2015/03/12 PHP
Javascript 垃圾收集机制介绍理解
2013/05/14 Javascript
js 一个关于图片onload加载的事
2013/11/10 Javascript
jQuery链使用指南
2015/01/20 Javascript
jQuery制作仿Mac Lion OS滚动条效果
2015/02/10 Javascript
javascript格式化日期时间方法汇总
2015/06/19 Javascript
AngualrJS中的Directive制作一个菜单
2016/01/26 Javascript
JavaScript对Json的增删改属性详解
2016/06/02 Javascript
nodejs基础应用
2017/02/03 NodeJs
jquery实现全选、全不选以及单选功能
2017/03/23 jQuery
ES6中Array.includes()函数的用法
2017/09/20 Javascript
解决Vue.js由于延时显示了{{message}}引用界面的问题
2018/08/25 Javascript
node中的session的具体使用
2018/09/14 Javascript
mpvue小程序循环动画开启暂停的实现方法
2019/05/15 Javascript
解决layui弹出层layer的area过大被遮挡的问题
2019/09/21 Javascript
jQuery使用ajax传递json对象到服务端及contentType的用法示例
2020/03/12 jQuery
jquery实现异步文件上传ajaxfileupload.js
2020/10/23 jQuery
[02:46]完美世界DOTA2联赛PWL DAY4集锦
2020/11/03 DOTA
Django中login_required装饰器的深入介绍
2017/11/24 Python
python利用thrift服务读取hbase数据的方法
2018/12/27 Python
Python如何获取Win7,Win10系统缩放大小
2020/01/10 Python
pycharm配置python 设置pip安装源为豆瓣源
2021/02/05 Python
你应该知道的30个css选择器
2014/03/19 HTML / CSS
美国马匹用品和骑马配件购物网站:Horse.com
2018/01/08 全球购物
澳大利亚排名第一的露营和户外设备在线零售商:Outbax
2020/05/06 全球购物
编写一个类体现构造,公有,私有方法,静态,私有变量
2013/08/10 面试题
中专生毕业自我鉴定
2013/11/01 职场文书
电子商务网站的创业计划书
2014/01/05 职场文书
2014年三八妇女节活动方案
2014/02/28 职场文书
介绍信格式
2015/01/30 职场文书
欠条格式范本
2015/07/03 职场文书
CSS3实现的文字弹出特效
2021/04/16 HTML / CSS
MongoDB使用profile分析慢查询的步骤
2021/04/30 MongoDB
Golang标准库syscall详解(什么是系统调用)
2021/05/25 Golang
Nginx配置之实现多台服务器负载均衡
2021/08/02 Servers