python AES 加密

本文介绍了一种使用Python实现的AES加密和解密方法,详细展示了如何通过填充和CBC模式来处理不同长度的字符串,确保数据的安全传输。通过具体代码示例,读者可以了解AES加解密的具体操作流程。
#!/usr/bin/python3
# -*- coding:utf-8 -*-
from Cryptodome.Cipher import AES
from binascii import b2a_hex, a2b_hex

# AES加密秘钥
AES_CRYPTO_KEY = "AIoT_DMS-LJG"

DEFAULT_USER_PWD = "123456"


def add_to_16(pad_text):
    if len(pad_text.encode('utf-8')) % 16:
        add = 16 - (len(pad_text.encode('utf-8')) % 16)
    else:
        add = 0
    pad_text += '\0' * add
    return pad_text.encode('utf-8')


def encrypt(encrypt_str, key=AES_CRYPTO_KEY):
    key_16 = add_to_16(key)
    #字符串转bytes且为16倍数个
    text_16 = add_to_16(encrypt_str)
    aes = AES.new(key_16, AES.MODE_CBC, key_16)
    cipher_text = aes.encrypt(text_16)
    # bytes转为字符串
    return str(b2a_hex(cipher_text),encoding="utf8")


def decrypt(decrypt_str, key=AES_CRYPTO_KEY):
    #字符串转为bytes
    decrypt_str_b = bytes(decrypt_str, encoding="utf8")
    key_16 = add_to_16(key)
    aes = AES.new(key_16, AES.MODE_CBC, key_16)
    plain_text = aes.decrypt(a2b_hex(decrypt_str_b))
    # 解密后,去掉补足的空格用strip() 去掉
    return bytes.decode(plain_text).rstrip('\0')


if __name__ == '__main__':
    text = "123456"
    e = encrypt(text)  # 加密
    d = decrypt(e)  # 解密
    print('原文:' + text)
    print('密文:' + e)
    print('长度:' + str(len(e)))
    print('解密:' + d)
    if text == d:
        print('解密结果:ok')
    else:
        print('解密结果:fail')

结果如下:

 

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值