本文主要解决的问题

本文主要是讲解AES加密算法中的ECB模式的加密解密的Python3.7实现。具体AES加密算法的原理这里不做过多介绍,想了解的可以参考文末的参考链接。

主要解决了两个问题:

  1. 在Python3.7版本下,所依赖包的安装问题。(有一些博客时间久远,其中所提到的模块并不适用于Python3.7)
  2. 因为Python版本的问题,其他博客在基于Python3.6下的代码在Python3.7下并不能运行的问题

背景介绍

在爬虫项目中遇到,某些网站的账号、密码采用了AES的ECB模式进行了加密。

  1. # 加密前的数据
  2. 123456asd
  3. # 加密后的数据
  4. 3cfeba82c31b6635e8fb085e04529e74
  5. # 密钥
  6. 8NONwyJtHesysWpM

使用在线AES加密解密、AES在线加密解密,进行尝试。

经过测试发现,在AES加密的ECB模式,填充为pkcs7padding ,数据块为128位,输出格式为hex时,得到自己想要的结果。

(这里可以可以根据密文的格式进行判断输出的格式,一般密文以==结尾的输出格式为base64,否则为hex格式)

问题1:Crypto模块安装报错

pip 安装 pycrypto模块,抛如下错误:

  1. error: command 'C:\\Program Files (x86)\\Microsoft Visual Studio 14.0\\VC\\BIN\\cl.exe' failed with exit status 2

解决方法:

详见python3.7安装pycrypto

问题2:网上copy来的代码报错

在网上博客中直接copy来的代码,可能会抛如下错误。

  1. TypeError: Object type <class 'str'> cannot be passed to C code

换个博客,发现依旧是这个错误。

错误原因

之前版本的代码并不适用于Python3.7。需要进行修改。

修改后的代码:

  1. import base64
  2. from Crypto.Cipher import AES
  3. import binascii
  4. def add_to_16(text):
  5. while len(text) % 16 != 0:
  6. text += '\0'
  7. return text
  8. def encrypt(data, password):
  9. if isinstance(password, str):
  10. password = password.encode('utf8')
  11. bs = AES.block_size
  12. pad = lambda s: s + (bs - len(s) % bs) * chr(bs - len(s) % bs)
  13. cipher = AES.new(password, AES.MODE_ECB)
  14. data = cipher.encrypt(pad(data).encode('utf8'))
  15. encrypt_data = binascii.b2a_hex(data) # 输出hex
  16. # encrypt_data = base64.b64encode(data) # 取消注释,输出Base64格式
  17. return encrypt_data.decode('utf8')
  18. def decrypt(decrData, password):
  19. if isinstance(password, str):
  20. password = password.encode('utf8')
  21. cipher = AES.new(password, AES.MODE_ECB)
  22. plain_text = cipher.decrypt(binascii.a2b_hex(decrData))
  23. return plain_text.decode('utf8').rstrip('\0')
  24. if __name__ == '__main__':
  25. data = '123456asd' # 待加密数据
  26. password = '8NONwyJtHesysWpM' # 16,24,32位长的密码(密钥)
  27. password = add_to_16(password)
  28. encrypt_data = encrypt(data, password)
  29. print('加密前数据:{}\n======================='.format(data))
  30. print('加密后的数据:', encrypt_data)
  31. decrypt_data = decrypt(encrypt_data, password)
  32. print('解密后的数据:{}'.format(decrypt_data))

参考

python 加密解密

AES ECB PKCS5/PKCS7 加解密 python实现 支持中文

python3.7 利用Crypto进行AES解密&加密文件

python3.7安装pycrypto

关注公众号西加加先生一起玩转Python

AES中ECB模式的加密与解密(Python3.7)的更多相关文章

  1. C#.NET中对称和非对称加密、解密方法汇总--亲测可用

    C#.NET中对称和非对称加密.解密方法汇总--亲测可用   在安全性要求比较高的系统中都会涉及到数据的加密.解密..NET为我们封装了常用的加密算法,例如:MD5,DES,RSA等.有可逆加密,也有 ...

  2. AES采用CBC模式128bit加密工具类

    写在前面 安全测试ECB模式过于简单需要改为CBC模式加密以下为工具类及测试 AESUtils.java package com.sgcc.mobile.utils; import sun.misc. ...

  3. 在C#中使用RSA进行加密和解密

    这篇文章向您展示了如何在c#.net Windows窗体应用程序中使用RSA算法对字符串进行加密和解密.RSA是由Ron Rivest,Adi Shamir和Leonard Adleman开发的非对称 ...

  4. python中对RSA的加密和解密

    首先,生成一对密钥,并保存 def create_keys(): # 生成公钥和私钥 (pubkey, privkey) = rsa.newkeys(1024) pub = pubkey.save_p ...

  5. c# aes,des,md5加密等解密算法

    一:可逆加密,即是能加密也能解密 对称可逆加密:加密后能解密回原文,加密key和解密key是一个 加密算法都是公开的,密钥是保密的, 即使拿到密文 你是推算不了密钥 也推算不了原文 加密解密的速度快, ...

  6. C#中常用的字符串加密,解密方法封装,包含只加密,不解密的方法

    //方法一//须添加对System.Web的引用//using System.Web.Security;/// <summary>/// SHA1加密字符串/// </summary ...

  7. C#中对字符串的加密和解密

    加密: /// <summary> /// 对字符串进行加密 /// </summary> /// <param name="proclaimText" ...

  8. python 实现 AES ECB模式加解密

    AES ECB模式加解密使用cryptopp完成AES的ECB模式进行加解密. AES加密数据块分组长度必须为128比特,密钥长度可以是128比特.192比特.256比特中的任意一个.(8比特 == ...

  9. iOS开发之 AES+Base64数据混合加密与解密

    2016-04-08 09:03 编辑: liubinqww 分类:iOS开发 来源:liubinqww 投稿 4 889     "APP的数据安全已经牵动着我们开发者的心,简单的MD5/ ...

随机推荐

  1. HDU 1754线段树基本操作,建树,更新,查询

    代码线段树入门整理中有介绍. #include<cstdio> #include<algorithm> #include<cstring> #include< ...

  2. 常用的python内建函数

    raw_input() 函数说明 函数签名:raw_input([prompt]) 使用形式如下: raw_input([prompt]) -> string 如果提供了参数prompt,就会在 ...

  3. Study in JI During the Summer Vacation

    15/07/2019-21/07/2019 Task List: 1.uow homework including vocabulary and listening 2.ASL's dictation ...

  4. phpStudy中升级MySQL版本到5.7.17的方法步骤

    http://www.jb51.net/article/120263.htm 前言 今天在工作发现一个错误,在往本地导数据表的时候老是报错: ? 1 [Err] 1294 - Invalid ON U ...

  5. http请求头包括了哪些常见内容

    Host: www.study.com                // 请求的地址域名和端口,不包括协议 Connection: keep-alive    // 连接类型,持续连接 Upgrad ...

  6. java 基本数据类型的自动拆箱与装箱

    ——>  -128~127之间的特殊性.为什么要这样设计,好处? ——>  享元模式(Flyweight Pattern):享元模式的特点是,复用我们内存中已存在的对象,降低系统创建对象实 ...

  7. webpack4.0基本配置,超简单!

    最近复习了一下webpack,使用的是4.0版本. 下图是基本目录结构,最后留有代码地址,有兴趣可以去看看. 直接上代码(依赖未完全使用): 项目的所有依赖都可以安装,每个都有详细的注释.] cons ...

  8. C# 性能分析 反射 VS 配置文件 VS 预编译

    本文分析在 C# 中使用反射和配置文件和预编译做注入的性能,本文的数据是为预编译框架,开发高性能应用 - 课程 - 微软技术暨生态大会 2018 - walterlv提供 本文通过代码生成工具,使用C ...

  9. 记一次奇葩事——html5可能不支持window.onscroll函数

    只在html5里遇到,html4没事:拿出来聊聊,路过帮忙解答下!!! 不正常的 <!doctype html><html><head><meta chars ...

  10. 【hdu 1849】Rabbit and Grass

    Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submission(s) ...