AES加密方式有五种:ECB, CBC, CTR, CFB, OFB

从安全性角度推荐CBC加密方法,本文介绍了CBC,ECB两种加密方法的python实现

python 在 Windows下使用AES时要安装的是pycryptodome 模块

pip install pycryptodome

python 在 Linux下使用AES时要安装的是pycrypto模块

pip install pycrypto

CBC加密需要一个十六位的key(密钥)和一个十六位iv(偏移量)

ECB加密不需要iv

AES CBC 加密的python实现

from Crypto.Cipher import AES

from binascii import b2a_hex, a2b_hex

# 如果text不足16位的倍数就用空格补足为16位

def add_to_16(text):

if len(text.encode('utf-8')) % 16:

add = 16 - (len(text.encode('utf-8')) % 16)

else:

add = 0

text = text + ('\0' * add)

return text.encode('utf-8')

# 加密函数

def encrypt(text):

key = '9999999999999999'.encode('utf-8')

mode = AES.MODE_CBC

iv = b'qqqqqqqqqqqqqqqq'

text = add_to_16(text)

cryptos = AES.new(key, mode, iv)

cipher_text = cryptos.encrypt(text)

# 因为AES加密后的字符串不一定是ascii字符集的,输出保存可能存在问题,所以这里转为16进制字符串

return b2a_hex(cipher_text)

# 解密后,去掉补足的空格用strip() 去掉

def decrypt(text):

key = '9999999999999999'.encode('utf-8')

iv = b'qqqqqqqqqqqqqqqq'

mode = AES.MODE_CBC

cryptos = AES.new(key, mode, iv)

plain_text = cryptos.decrypt(a2b_hex(text))

return bytes.decode(plain_text).rstrip('\0')

if __name__ == '__main__':

e = encrypt("hello world") # 加密

d = decrypt(e) # 解密

print("加密:", e)

print("解密:", d)

AES ECB加密的python实现

"""

ECB没有偏移量

"""

from Crypto.Cipher import AES

from binascii import b2a_hex, a2b_hex

def add_to_16(text):

if len(text.encode('utf-8')) % 16:

add = 16 - (len(text.encode('utf-8')) % 16)

else:

add = 0

text = text + ('\0' * add)

return text.encode('utf-8')

# 加密函数

def encrypt(text):

key = '9999999999999999'.encode('utf-8')

mode = AES.MODE_ECB

text = add_to_16(text)

cryptos = AES.new(key, mode)

cipher_text = cryptos.encrypt(text)

return b2a_hex(cipher_text)

# 解密后,去掉补足的空格用strip() 去掉

def decrypt(text):

key = '9999999999999999'.encode('utf-8')

mode = AES.MODE_ECB

cryptor = AES.new(key, mode)

plain_text = cryptor.decrypt(a2b_hex(text))

return bytes.decode(plain_text).rstrip('\0')

if __name__ == '__main__':

e = encrypt("hello world") # 加密

d = decrypt(e) # 解密

print("加密:", e)

print("解密:", d)

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

本文标题: python实现AES加密与解密

本文地址: http://www.cppcns.com/jiaoben/python/255731.html

python实现字母的加密和解密 字典_python实现AES加密与解密相关推荐

  1. 解密HLS中的AES加密

    解密HLS中的AES加密 主题 加密解密 如果m3u8文件中包含#EXT-X-KEY字段,那么可以断定这个HLS中的ts文件是被加密的,如: #EXTM3U#EXT-X-VERSION:3#EXT-X ...

  2. cbc cryptojs 前后端_前端CryptoJS AES/DES加解密与后端PHP AES/DES加解密

    本文涉及到的内容有:前端使用CryptoJS对数据进行DES或AES加密解密: 后端使用PHP openssl对数据进行解密和加密. 前端AES加密数据 首先在vue环境下安装crypto-js,cr ...

  3. python 加密解密_python实现AES加密解密

    本文实例为大家分享了python实现AES加密解密的具体代码,供大家参考,具体内容如下 (1)对于AES加密解密相关知识 (2)实现的功能就是输入0-16个字符,然后经过AES的加密解密最后可以得到原 ...

  4. python调用库函数用ecb模式加密图片_python 实现AES加密解密(ECB模式,配合base64)...

    import base64 from Crypto.Cipher import AES ''' 采用AES对称加密算法 ''' # str不是32的倍数那就补足为16的倍数 def add_to_32 ...

  5. openssl 加密解密 指令_openssl命令aes加密和解密

    openssl命令aes加密和解密 日期:2014-11-12 10:41:25 最后更新日期:2017-07-06 10:00:10 [技术] man openssl查看openssl的功能: [c ...

  6. php7.1 aes 加密解密,PHP7.1中AES加密解密方法 mcrypt_module_open()替换方案

    mcrypt 扩展已经过时了大约10年,并且用起来很复杂.因此它被废弃并且被 OpenSSL 所取代. 从PHP 7.2起它将被从核心代码中移除并且移到PECL中. PHP手册在7.1迁移页面给出了替 ...

  7. javascript 解密_Javascript中的AES加密和Java中的解密

    javascript 解密 AES代表高级加密系统,它是一种对称加密算法,很多时候我们需要在客户端加密一些纯文本,例如密码,然后将其发送到服务器,然后由服务器解密以进行进一步处理.AES加密和解密更加 ...

  8. python统计字母出现次数用while循环_Python—变量,条件语句,while循环,运算符,字符串等...

    Python初识以及变量: 变量名:--字母 --数字 --下划线[见名识意] (PS:数字不能开头:不能是关键字:最好不能和python内置的东西重复) ###################### ...

  9. AES加密解密python实现

    1.前言 关于现代密码学算法,可以查看以下博客全面了解 CISSP考试要求里的"应用密码学"内容辅助记忆趣味串讲_晓翔仔的博客-CSDN博客 AES的细节知识,可以查阅 AES加密 ...

最新文章

  1. Service Worker
  2. AI顶会组团“改版”:NeurIPS 2020宣布deadline延期三周
  3. 中画图title函数_MATLAB-基础画图meshgrid
  4. 后疫情时代怎么办?来看看联想的智慧答卷
  5. 卷积神经网络模型如何辨识裸体图片
  6. 剑指offer 二叉搜索树的后序遍历
  7. [Swift]LeetCode483. 最小好进制 | Smallest Good Base
  8. C#面向对象设计模式第九讲:Composite 组合模式(结构型模式)
  9. 面向对象程序设计简介
  10. gamma软件linux安装图示,[转载]linux下安装GAMMA软件
  11. 从技术角度,设备过保就坏,是怎么实现的
  12. xv6实验课程:Xv6和Unix实用程序
  13. 计算机绘图软件应用于哪些领域,计算机绘图软件在环境艺术设计中的运用
  14. CSS 小技巧:如何保留 hover 的状态?
  15. 适合各种创业者借鉴的案例,老板创业2个小时卖了9万元!
  16. JS的迭代器和可迭代对象详解
  17. 高可用解决方案:同城双活?异地双活?异地多活?怎么实现?
  18. Java实现对PDF文件添加水印
  19. 关于Win10的powerdesigner16的缩放问题,字体和图标
  20. beyond compare java_文件内容比较工具---Text compare Beyond compare

热门文章

  1. 排除“使用主题 css 文件要求页上有标头控件。(例如 head runat=server /)”错误...
  2. Redis如何支持高并发的访问
  3. 数据千万条,安全第一条
  4. spring整合hibernate出现NoClassDefFoundError: org/apache/commons/collections/map/LRUMap
  5. xpath里面if判断一个值不为空_现代C++之模板元编程(今天写个If与While)
  6. 01 | 基础架构:一条SQL查询语句是如何执行的?笔记(转)
  7. Redlock原理简介和实现过程
  8. linux系统防火墙配置浅谈
  9. Maven入门基础-环境篇
  10. 你还在纠结要不要学 Go 吗?