在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 相关文章推荐
Python3.x和Python2.x的区别介绍
Feb 12 Python
Python操作SQLite简明教程
Jul 10 Python
Python实现全角半角转换的方法
Aug 18 Python
Python中列表(list)操作方法汇总
Aug 18 Python
利用python如何处理百万条数据(适用java新手)
Jun 06 Python
python实现简易内存监控
Jun 21 Python
Anaconda下配置python+opencv+contribx的实例讲解
Aug 06 Python
pycharm的console输入实现换行的方法
Jan 16 Python
python 进程的几种创建方式详解
Aug 29 Python
Python使用uuid库生成唯一标识ID
Feb 12 Python
Python爬取12306车次信息代码详解
Aug 12 Python
Pytorch中Softmax与LogSigmoid的对比分析
Jun 05 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
.htaccess文件保护实例讲解
2011/02/06 PHP
PHP中file_exists与is_file,is_dir的区别介绍
2012/09/12 PHP
PHP中使用TCPDF生成PDF文档实例
2014/07/01 PHP
PHP中实现crontab代码分享
2015/03/26 PHP
php常用表单验证类用法实例
2015/06/18 PHP
PHP 信号管理知识整理汇总
2017/02/19 PHP
PHP 实现公历日期与农历日期的互转换
2017/09/13 PHP
不使用浏览器运行javascript代码的方法
2013/07/24 Javascript
Node.js事件循环(Event Loop)和线程池详解
2015/01/28 Javascript
学习JavaScript编程语言的8张思维导图分享
2015/03/27 Javascript
终于实现了!精彩的jquery弹幕效果
2016/07/18 Javascript
浅谈Javascript中的12种DOM节点类型
2016/08/19 Javascript
详解用原生JavaScript实现jQuery的某些简单功能
2016/12/19 Javascript
Angularjs 与 bower安装和使用详解
2017/05/11 Javascript
jQuery 实现双击编辑表格功能
2017/06/19 jQuery
nodejs socket服务端和客户端简单通信功能
2017/09/14 NodeJs
深入理解JavaScript和TypeScript中的class
2018/04/22 Javascript
Angular7中创建组件/自定义指令/管道的方法实例详解
2019/04/02 Javascript
使用Three.js实现太阳系八大行星的自转公转示例代码
2019/04/09 Javascript
Vue实现拖放排序功能的实例代码
2019/07/08 Javascript
JavaScript实现图片合成下载的示例
2020/11/19 Javascript
Python中多线程及程序锁浅析
2015/01/21 Python
python爬虫入门教程--优雅的HTTP库requests(二)
2017/05/25 Python
Python学习教程之常用的内置函数大全
2017/07/14 Python
Python3 Random模块代码详解
2017/12/04 Python
Python 网络爬虫--关于简单的模拟登录实例讲解
2018/06/01 Python
python实现文件分片上传的接口自动化
2020/11/19 Python
乐高奥地利官方商店:LEGO Shop AT
2019/07/16 全球购物
某IT外企面试题-二分法求方程!看看大家的C++功底
2015/07/04 面试题
12月小学生校园广播稿
2014/02/04 职场文书
工程技术员岗位职责
2014/03/02 职场文书
2014婚礼司仪主持词
2014/03/14 职场文书
离婚协议书怎么写(范本参考)
2014/09/30 职场文书
2016年党支部公开承诺书
2016/03/25 职场文书
2016年中学法制宣传日活动总结
2016/04/01 职场文书
Python自动化爬取天眼查数据的实现
2021/06/15 Python