当前位置: 首页 > 工具软件 > python-mode > 使用案例 >

Python ---AES.MODE_ECB 加密、解密

谷星文
2023-12-01

环境准备:
python 3.6
# pip install pycryptodome
一、概念
1、对称加密:
对称加密是指加密和解密使用同一个密钥的加密方式。
2、对称加密过程:
发送方使用密钥将明文数据加密成密文,然后发送出去,接收方收到密文后,使用同一个密钥将密文解密成明文读取。
3、对称加密的优点:
加密计算量小、速度快,适合对大量数据进行加密
4、对称加密的缺点:
密钥传输安全问题
密钥数量越多,面临管理问题越多
5、ASE 加密算法:
ASE 加密算法,是对称加密算法的一种
6、ASE 常用的加密模式:

二、常用的加密模式有 5 种:
 1.电码本模式(Electronic Codebook Book (ECB));
 2.密码分组链接模式(Cipher Block Chaining (CBC));
 3.计算器模式(Counter (CTR));
 4.密码反馈模式(Cipher FeedBack (CFB));
 5.输出反馈模式(Output FeedBack (OFB))。
四种模式除了 ECB 相对不安全外,其它模式没有太大的差别

三、代码

# !/usr/bin/python
# -*- coding: utf-8 -*-

"""
 补0方式
"""

import base64

from Crypto.Cipher import AES


# 补足字符串长度为16的倍数
def add_to_16(s):
    while len(s) % 16 != 0:
        s += '\0'
    return str.encode(s)  # 返回bytes

key = '244F3C2C1AB08F70'.upper()
key = '1234567890123456'  # 密钥长度必须为16、24或32位,分别对应AES-128、AES-192和AES-256
text = 'abcdefg'  # 待加密文本

aes = AES.new(str.encode(key), AES.MODE_ECB)  # 初始化加密器,本例采用ECB加密模式
encrypted_text = str(base64.encodebytes(aes.encrypt(add_to_16(text))), encoding='utf8').replace('\n', '')  # 加密
decrypted_text = str(
    aes.decrypt(base64.decodebytes(bytes(encrypted_text, encoding='utf8'))).rstrip(b'\0').decode("utf8"))  # 解密

print('加密值:', encrypted_text)
print('解密值:', decrypted_text)

 

方法写法:

import base64
from Crypto.Cipher import AES

'''
采用AES对称加密算法
'''
# str不是32的倍数那就补足为16的倍数
def add_to_32(value):
    while len(value) % 32 != 0:
        value += '\0'
    return str.encode(value)  # 返回bytes
#加密方法
def encrypt_oracle(text):
    # 秘钥
    key = 'lymhqnoetl15321'
    # 待加密文本
    # 初始化加密器
    aes = AES.new(add_to_32(key), AES.MODE_ECB)
    #先进行aes加密
    encrypt_aes = aes.encrypt(add_to_32(text))
    #用base64转成字符串形式
    encrypted_text = str(base64.encodebytes(encrypt_aes), encoding='utf-8')  # 执行加密并转码返回bytes
    print(encrypted_text)
    return encrypted_text
#解密方法
def decrypt_oralce(text):
    # 秘钥
    key = 'lymhqnoetl15321'
    # 密文
    # 初始化加密器
    aes = AES.new(add_to_32(key), AES.MODE_ECB)
    #优先逆向解密base64成bytes
    base64_decrypted = base64.decodebytes(text.encode(encoding='utf-8'))
    #执行解密密并转码返回str
    decrypted_text = str(aes.decrypt(base64_decrypted),encoding='utf-8').replace('\0','') 
    return decrypted_text

if __name__ == '__main__':
   # encrypt_oracle()
    encrypt_oracle('abcdefg')

 

 类似资料: