python 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')

结果如下:

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值