AES的加解密-python样例程序

from Crypto.Cipher import AES
from Crypto.Random import get_random_bytes
from Crypto.Protocol.KDF import PBKDF2


def generate_key_and_iv(password, salt, key_size=32, iv_size=16):
    key_iv = PBKDF2(password, salt, dkLen=key_size + iv_size, count=100000)
    return key_iv[:key_size], key_iv[key_size:]


def encrypt_AES_CBC(message, password):
    salt = get_random_bytes(16)
    key, iv = generate_key_and_iv(password, salt)

    cipher = AES.new(key, AES.MODE_CBC, iv)
    #ciphertext = cipher.encrypt(pad(message.encode('utf-8'), [①]))
    ciphertext = cipher.encrypt(pad(message.encode('utf-8'), AES.block_size))
    return salt + ciphertext

def decrypt_AES_CBC(ciphertext, password):
    salt = ciphertext[:16]
    #ciphertext = ciphertext[②]
    ciphertext = ciphertext[16:]
    key, iv = generate_key_and_iv(password, salt)

    cipher = AES.new(key, AES.MODE_CBC, iv)
    decrypted_message = unpad(cipher.decrypt(ciphertext), AES.block_size)
    return decrypted_message.decode('utf-8')

def pad(message, block_size):
    #padding_size = block_size - len(message) % [③]
    padding_size = block_size - len(message) % block_size
    padding = bytes([padding_size] * padding_size)
    return message + padding

def unpad(padded_message, block_size):
    #padding_size = [④]
    padding_size = padded_message[-1]
    if padding_size < 1 or padding_size > block_size:
        raise ValueError("Invalid padding")
    if padded_message[-padding_size:] != bytes([padding_size] * padding_size):
        raise ValueError("Invalid padding")
    return padded_message[:-padding_size]

if __name__ == "__main__":
    # 要加密的消息和密码
    message = "Hello, this is a message to be encrypted using AES!"
    password = "1234456"

    # 加密46
    encrypted_data = encrypt_AES_CBC(message, password)
    print("Encrypted:", encrypted_data)

    # 解密
    decrypted_message = decrypt_AES_CBC(encrypted_data, password)
    print("Decrypted:", decrypted_message)

你可能感兴趣的:(python)