在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基于urllib实现按照百度音乐分类下载mp3的方法
May 25 Python
Python实现判断字符串中包含某个字符的判断函数示例
Jan 08 Python
python中正则表达式 re.findall 用法
Oct 23 Python
python匹配两个短语之间的字符实例
Dec 25 Python
Django 中自定义 Admin 样式与功能的实现方法
Jul 04 Python
使用python写的opencv实时监测和解析二维码和条形码
Aug 14 Python
python3.8下载及安装步骤详解
Jan 15 Python
Python pip配置国内源的方法
Feb 14 Python
Python多线程通信queue队列用法实例分析
Mar 24 Python
python3 sleep 延时秒 毫秒实例
May 04 Python
使用Python爬虫爬取小红书完完整整的全过程
Jan 19 Python
PyQt 如何创建自定义QWidget
Mar 24 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代码把全角数字转为半角数字
2007/12/10 PHP
PHP函数篇详解十进制、二进制、八进制和十六进制转换函数说明
2011/12/05 PHP
phpQuery占用内存过多的处理方法
2013/11/13 PHP
完美解决thinkphp验证码出错无法显示的方法
2014/12/09 PHP
关于laravel5.5的定时任务详解(demo)
2019/10/23 PHP
pjblog中的UBBCode.js
2007/04/25 Javascript
dwr spring的集成实现代码
2009/03/22 Javascript
javascript 解析url的search方法
2010/02/09 Javascript
JS获取当前网页大小以及屏幕分辨率等
2014/09/05 Javascript
JS基于面向对象实现的放烟花效果
2015/05/07 Javascript
jquery插件Jplayer使用方法简析
2016/04/22 Javascript
原生JS实现旋转木马式图片轮播插件
2016/04/25 Javascript
Bootstrap3使用typeahead插件实现自动补全功能
2016/07/07 Javascript
微信JSAPI Ticket接口签名详解
2020/06/28 Javascript
详解NodeJs开发微信公众号
2018/05/25 NodeJs
[51:17]Mski vs VGJ.S Supermajor小组赛C组 BO3 第三场 6.3
2018/06/04 DOTA
Python实现的生成自我描述脚本分享(很有意思的程序)
2014/07/18 Python
基于python(urlparse)模板的使用方法总结
2017/10/13 Python
Python(Django)项目与Apache的管理交互的方法
2018/05/16 Python
python切片及sys.argv[]用法详解
2018/05/25 Python
实例讲解Python爬取网页数据
2018/07/08 Python
python3.7将代码打包成exe程序并添加图标的方法
2019/10/11 Python
python pymysql链接数据库查询结果转为Dataframe实例
2020/06/05 Python
python生成xml时规定dtd实例方法
2020/09/21 Python
python中复数的共轭复数知识点总结
2020/12/06 Python
python实现简单的井字棋游戏(gui界面)
2021/01/22 Python
pandas统计重复值次数的方法实现
2021/02/20 Python
美国女性卫生用品公司:Thinx
2017/06/30 全球购物
什么是Oracle的后台进程background processes?都有哪些后台进程?
2012/04/26 面试题
读书活动总结
2014/04/28 职场文书
节水口号标语
2014/06/19 职场文书
人大调研汇报材料
2014/08/14 职场文书
企业2014年度工作总结
2014/12/10 职场文书
pytorch 如何使用amp进行混合精度训练
2021/05/24 Python
JavaScript严格模式不支持八进制的问题讲解
2021/11/07 Javascript
JS实现页面炫酷的时钟特效示例
2022/08/14 Javascript