针对密钥和密文明文都是ascii(hex)形式进行aes_ecb加密和解密
import binascii
from cryptography.hazmat.backends import default_backend
from cryptography.hazmat.primitives.ciphers import Cipher, algorithms, modes
from cryptography.hazmat.primitives.padding import PKCS7
key = binascii.unhexlify('68656c6c6f776f726c6468656c6c6f31')
print('key: {}'.format(key))
def aes_ecb_encrypt(text):
encryptor = Cipher(
algorithms.AES(key),
modes.ECB(),
backend=default_backend(),
).encryptor()
padder = PKCS7(128).padder()
cipher_text = encryptor.update(padder.update(text) + padder.finalize())
return cipher_text
def aes_ecb_decrypt(text):
decryptor = Cipher(
algorithms.AES(key),
modes.ECB(),
backend=default_backend()
).decryptor()
de_text = decryptor.update(binascii.unhexlify(text))
de_text = str(de_text).replace(r'\x05', '')
return de_text
if __name__ == '__main__':
cipher_text = aes_ecb_encrypt(b'12345678910')
print('cipher_text: {}'.format(cipher_text))
hex_text = binascii.hexlify(cipher_text)
print('hex_text: {}'.format(hex_text))
plaintext = aes_ecb_decrypt(hex_text)
print('plaintext: {}'.format(plaintext))