python aes解密_Python: AES加密与解密

这篇博客介绍了如何使用Python实现AES加密和解密,主要涉及Python Cryptography Toolkit (pycrypto)库,详细讲解了加密解密的过程,并给出了完整的代码示例。同时,博主分享了在使用过程中遇到的问题和解决方法。
摘要由CSDN通过智能技术生成

起源:

视频下载,解析到一个网站时,发现其视频id是用AES加密过的,用的是https://code.google.com/archive/p/crypto-js/这个库。

解密很简单的一句js代码:

t.video = CryptoJS.AES.decrypt(t.video, secret).toString(CryptoJS.enc.Utf8);

原本想着简单,找段python代码做解密是了,没想到反复尝试,写法五花八门多种多样,就是解不出来,竟费去许多工夫!

如何简单?我只需实现验证下面的字串加解密:

#data = '-85297962_172051801'

#key = '583a01a9ba901a3adda7252ebca42c09'

#encrypt_data = 'U2FsdGVkX192df0Gxgia8s93zZp85f9m2nU1VIGU+RZQDtViB1LPBnE0CBWgVDBj'

1、Python Cryptography Toolkit (pycrypto)

加解密需要用到它,其网址是:https://pypi.python.org/pypi/pycrypto目前最新版本为2.6.1。如何安装及其简单Demo,其页面上都 ,而其用法在网上一搜也到处都是,可就是不能解决我的问题,我想是我用错了,但哪种才是对的哪!

crypto-js这个,应该用的是AES默认模式,AES.MODE_CBC。js代码也是难懂,总是不停试不停试!

2、加密与解密

直接上代码吧,它满足了需求:

#coding=utf-8

importbase64from Crypto.Cipher importAESfrom Crypto importRandomfrom hashlib importmd5

BLOCK_SIZE=AES.block_sizedefpad(data):

length= BLOCK_SIZE - (len(data) %BLOCK_SIZE)return data + (chr(length) *length).encode()defunpad(data):return data[:-(data[-1] if type(data[-1]) == int else ord(data[-1]))]def bytes_to_key(my_data, salt, output=48):#extended from https://gist.github.com/gsakkis/4546068

assert len(salt) == 8, len(salt)

my_data+=salt

key=md5(my_data).digest()

final_key=keywhile len(final_key)

key= md5(key +my_data).digest()

final_key+=keyreturnfinal_key[:output]defencrypt(message, passphrase):

salt= Random.new().read(8)

key_iv= bytes_to_key(passphrase, salt, 32 + 16)

key= key_iv[:32]

iv= key_iv[32:]

aes=AES.new(key, AES.MODE_CBC, iv)return base64.b64encode(b"Salted__" + salt +aes.encrypt(pad(message)))defdecrypt(data, password):if len(data) <=BLOCK_SIZE:returndata

data=base64.b64decode(data)

salt= data[8:16]

key_iv= bytes_to_key(password, salt, 32 + 16)

key= key_iv[:32]

iv= key_iv[32:]

cipher=AES.new(key, AES.MODE_CBC, iv)returnunpad(cipher.decrypt(data[BLOCK_SIZE:]))if __name__ == '__main__':#data = '-85297962_172051801'

#key = '583a01a9ba901a3adda7252ebca42c09'

#encrypt_data = 'U2FsdGVkX192df0Gxgia8s93zZp85f9m2nU1VIGU+RZQDtViB1LPBnE0CBWgVDBj'

key= '583a01a9ba901a3adda7252ebca42c09'data= '-85297962_172051801'encrypt_data=encrypt(data, key)printencrypt_data#encrypt_data = 'U2FsdGVkX192df0Gxgia8s93zZp85f9m2nU1VIGU+RZQDtViB1LPBnE0CBWgVDBj'

decrypt_data =decrypt(encrypt_data, key)print 'decrypt_data:', decrypt_data

同个字串,发现加密后的字串,每次不尽相同。对AES没多研究,挺觉奇怪!

3、打包与发布

若是只用到了Crypto一部分功能,比如我们用到的aes解密,则可以抽简出来所需代码,以避免打入整个Crypto库。

#ifdef IS_PY3K

m= PyModule_Create(&moduledef);#elsem= Py_InitModule("Crypto.Cipher."_MODULE_STRING, modulemethods);#endif

而用py2exe打包抽取,其把Crypto\Cipher\_AES.pyd改名为Crypto.Cipher._AES.pyd文件,放与发布目录下,令人颇长见识

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值