Pyhton AES_cbc解密
最近很多朋友问我加密解密有没有啥好推荐的方式,一般对AES的加密解密方式直接用在线加密或者解密就行,我为了方便测试,将网址以python脚本的形式写了出来,很简单的东西,2分钟搞定,随手记录一下~~
先来了解下AES:
AES,高级加密标准(英语:Advanced Encryption Standard)。是用来替代DES,目前比较流行的加密算法。
它是一种对称加密的算法,AES只有一个密钥,这个密钥既用来加密,也用于解密。
AES只是个基本算法,实现AES有几种模式,主要有ECB、CBC、CFB和OFB这几种(其实还有个CTR):
1.ECB模式(电子密码本模式:Electronic codebook)
ECB是最简单的块密码加密模式,加密前根据加密块大小(如AES为128位)分成若干块,之后将每块使用相同的密钥单独加密,解密同理。
2.CBC模式(密码分组链接:Cipher-block chaining)
CBC模式对于每个待加密的密码块在加密前会先与前一个密码块的密文异或然后再用加密器加密。第一个明文块与一个叫初始化向量的数据块异或。
3.CFB模式(密文反馈:Cipher feedback)
与ECB和CBC模式只能够加密块数据不同,CFB能够将块密文(Block Cipher)转换为流密文(Stream Cipher)。
4.OFB模式(输出反馈:Output feedback)
OFB是先用块加密器生成密钥流(Keystream),然后再将密钥流与明文流异或得到密文流,解密是先用块加密器生成密钥流,再将密钥流与密文流异或得到明文,由于异或操作的对称性所以加密和解密的流程是完全一样的。
在线加密解密地址:http://tool.chacuo.net/cryptaes,很多人加密解密用python写用的是Crypto.Cipher,这里只是将在线解密以python的形式调了一下接口,直接用request的形式表示出来,其实质还是在线解密。。。
废话不多说了,直接上代码:
# -*- coding: utf-8 -*- import requests
#aes_test为存放需解析数据的.py文件 from aes_test import data formdata = { "data":data, "type":"aes",
#key为密钥 "arg":"m=cbc_pad=pkcs5_block=128_p=key_i=key_o=0_s=utf-8_t=1" } #有header传,没有可不传 # headers={ "User-Agent": "Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/51.0.2704.103 Safari/537.36"} url = "http://tool.chacuo.net/cryptaes" response = requests.post(url,data = formdata) # response = requests.post(url,data = formdata,headers=headers) print response.json()
此次只是为了方便测试,将在线解析转化了下,其本质不变,还是调用的在线解密,下次有时间再整理下Crypto.Cipher的方法~~