Python–AES加密与解密方法指导

起源:

视频下载,解析到一个网站时,发现其视频id是用AES加密过的,用的是这个库。
解密很简单的一句js代码:

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

登录后复制

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

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

    # data = '-85297962_172051801'# key = '583a01a9ba901a3adda7252ebca42c09'# encrypt_data = 'U2FsdGVkX192df0Gxgia8s93zZp85f9m2nU1VIGU+RZQDtViB1LPBnE0CBWgVDBj'

登录后复制

 

立即学习“Python免费学习笔记(深入)”;

1、Python Cryptography Toolkit (pycrypto)

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

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

 

立即学习“Python免费学习笔记(深入)”;

2、加密与解密

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

# coding=utf-8import base64from Crypto.Cipher import AESfrom Crypto import Randomfrom hashlib import md5BLOCK_SIZE = AES.block_sizedef pad(data):    length = BLOCK_SIZE - (len(data) % BLOCK_SIZE)return data + (chr(length) * length).encode()def unpad(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 assert len(salt) == 8, len(salt)    my_data += salt    key = md5(my_data).digest()    final_key = keywhile len(final_key) < output:        key = md5(key + my_data).digest()        final_key += keyreturn final_key[:output]def encrypt(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)))def decrypt(data, password):if len(data) <= BLOCK_SIZE:return data    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)return unpad(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)print encrypt_data# encrypt_data = 'U2FsdGVkX192df0Gxgia8s93zZp85f9m2nU1VIGU+RZQDtViB1LPBnE0CBWgVDBj'decrypt_data = decrypt(encrypt_data, key)print 'decrypt_data:', decrypt_data

登录后复制

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

 

立即学习“Python免费学习笔记(深入)”;

3、打包与发布

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

奇怪的是,引用_AES.pyd这个动态库,引用路径有问题。查阅资料,原来Crypto写死了它的引用路径,其页面代码有如此写:

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

登录后复制

 

立即学习“Python免费学习笔记(深入)”;

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

以上就是Python–AES加密与解密方法指导的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2268231.html

(0)
上一篇 2025年2月27日 10:37:22
下一篇 2025年2月23日 00:42:17

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • 电脑编程主流语言有哪些

    目前最流行的电脑编程语言:1. Python(数据科学、机器学习);2. Java(企业级应用程序);3. C++(高性能应用程序);4. C#(Windows 应用程序);5. JavaScript(动态 Web 页面);6. SQL(数…

    2025年2月27日
    200
  • Python基础入门–函数

    8.函数 函数是带名字的代码块,用于完成具体的工作。def函数定义,指出函数名。定义函数的时候,我们把参数的名字和位置确定下来,函数的接口定义就完成了。对于函数的调用者来说,只需要知道如何传递正确的参数,以及函数将返回什么样的值就够了,函数…

    编程技术 2025年2月27日
    200
  • python入门教程之列表操作

    python列表操作——增 append:追加一条数据到列表的最后 name = [“Zhangsan”,”XiongDa”,”Lisi”]name.append(“wangwu”)print name输出结果:[‘Zhangsan’, ‘…

    编程技术 2025年2月27日
    200
  • [flask/python/web]学习flask web开发(Miguel著)遇到的一些问题及其解决方案

    今天解决了第11章_不显示博文表单的问题,时间太晚了,先留个坑,明天写出详细的解决方案。 同时也将前11章(当我结束本书学习时会将所有的问题一一列出并给出中文的解决方案)的常见问题给予解答。 以上就是[flask/python/web]学习…

    编程技术 2025年2月27日
    200
  • 详细讲解Python中的元类及其用法

    1、用元类验证子类 每当我们定义新类的时候,元类就会运行雅正代码,以确保这个新类符合规定的规范。python系统把子类的class语句处理完毕,就会调用元类的 __new__ 方法。元类可以通过 __new__ 方法,获取子类、孙子类的名称…

    编程技术 2025年2月27日
    200
  • Python基础学习之类的介绍

      在python中,首字母大写的名称指的是类。这个类定义中的括号是空的,因为我们要从空白创建这个类。我们编写了一个文档字符串,对这个类的功能作了描述。类中的函数称为方法。   以Student类为例,在Python中,定义类是通过clas…

    编程技术 2025年2月27日
    200
  • Python中filecmp的简单使用

        filecmp模块用于比较文件及文件夹的内容,它是一个轻量级的工具,使用非常简单。python标准库还提供了difflib模块用于比较文件的内容。关于difflib模块,且听下回分解。     filecmp定义了两个函数,用于方便…

    2025年2月27日
    200
  • python序列之列表

    注:本文测试环境为python 2.7 列表(list),同数组不同,它既可以存储相同类型的数据,也可也存储不同类型的数据 list1 = [1,2,3] list2 = [1,’hello’,False] 列表属于序列,所以兼顾序列的一些…

    编程技术 2025年2月27日
    200
  • Python中关于数字的详解

    这篇文章主要介绍了python中的数字类型及基本的数学计算,与其他语言一样,除法相对复杂些,不过本文并未就此深入,需要的朋友可以参考下python不仅支持通常的数据类型(整数和浮点数),而且能够通过常量去直接创建数字以及处理数字的表达式。 …

    编程技术 2025年2月27日
    200
  • python的序列之列表的通用方法

    注:本文测试环境为 python2.7 注:本文主要介绍列表的通用方法 测试list list1 = [1,2,3,4]   立即学习“Python免费学习笔记(深入)”; insert方法: 方法解释:在指定位置插入对象 参数:   参数…

    编程技术 2025年2月27日
    200

发表回复

登录后才能评论