在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使用matplotlib实现在坐标系中画一个矩形的方法
May 20 Python
Python模块包中__init__.py文件功能分析
Jun 14 Python
Python调用微信公众平台接口操作示例
Jul 08 Python
Python的mysql数据库的更新如何实现
Jul 31 Python
Python实现变量数值交换及判断数组是否含有某个元素的方法
Sep 18 Python
详解Python异常处理中的Finally else的功能
Dec 29 Python
Python爬虫实例扒取2345天气预报
Mar 04 Python
python爬取微信公众号文章
Aug 31 Python
提升Python程序性能的7个习惯
Apr 14 Python
python使用正则来处理各种匹配问题
Dec 22 Python
Python loguru日志库之高效输出控制台日志和日志记录
Mar 07 Python
Python基于百度API识别并提取图片中文字
Jun 27 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中通过HTTP_USER_AGENT判断是否为手机移动终端的函数代码
2013/02/14 PHP
php setcookie(name, value, expires, path, domain, secure) 参数详解
2013/06/28 PHP
php用正则表达式匹配中文实例详解
2013/11/06 PHP
smarty模板判断数组为空的方法
2015/06/10 PHP
PHP实现文件下载【实例分享】
2017/04/28 PHP
php框架CodeIgniter使用redis的方法分析
2018/04/13 PHP
Yii框架自定义数据库操作组件示例
2019/11/11 PHP
javascrpt绑定事件之匿名函数无法解除绑定问题
2012/12/06 Javascript
jQuery页面图片伴随滚动条逐渐显示的小例子
2013/03/21 Javascript
使用jQuery动态加载js脚本文件的方法
2014/04/03 Javascript
JavaScript访问CSS属性的几种方式介绍
2014/07/21 Javascript
AngularJS入门知识之MVW类框架的编程思想探讨
2014/12/08 Javascript
JavaScript判断用户是否对表单进行了修改的方法
2015/03/18 Javascript
jQuery实现的仿百度分页足迹效果代码
2015/10/30 Javascript
JavaScript实现点击单元格改变背景色的方法
2016/02/12 Javascript
JavaScript获取当前时间向前推三个月的方法示例
2017/02/04 Javascript
Node.js pipe实现源码解析
2017/08/12 Javascript
Vue.js中的computed工作原理
2018/03/22 Javascript
[02:24]DOTA2痛苦女王 英雄基础教程
2013/11/26 DOTA
[00:12]2018DOTA2亚洲邀请赛 Sccc亮相SOLO赛,今年他又会有什么样的战绩?
2018/04/06 DOTA
深入理解Python中的元类(metaclass)
2015/02/14 Python
深入解析Python设计模式编程中建造者模式的使用
2016/03/02 Python
Python中的if、else、elif语句用法简明讲解
2016/03/11 Python
Pycharm远程调试openstack的方法
2017/11/21 Python
K-近邻算法的python实现代码分享
2017/12/09 Python
Python网络编程之TCP与UDP协议套接字用法示例
2018/02/02 Python
python实现AES和RSA加解密的方法
2019/03/28 Python
Flask框架实现的前端RSA加密与后端Python解密功能详解
2019/08/13 Python
python爬虫模块URL管理器模块用法解析
2020/02/03 Python
基于python模拟bfs和dfs代码实例
2020/11/19 Python
实例讲解CSS3中的border-radius属性
2015/08/18 HTML / CSS
Ryderwear美国官网:澳大利亚高端健身训练装备品牌
2018/04/24 全球购物
市场营销职业生涯规划书范文
2014/01/12 职场文书
社保代办委托书怎么写
2014/10/06 职场文书
2014年电话客服工作总结
2014/12/09 职场文书
Python+Tkinter打造签名设计工具
2022/04/01 Python