python 使用AES加解密

本文介绍了如何在Python中使用AES进行加密和解密操作。通过导入`base64`和`Crypto`库,创建了一个名为`Encrypt`的类,该类包含初始化方法和`encrypt`、`decrypt`方法,用于加密和解密文本。加密过程中,如果文本长度不是16的倍数,会补足空格使其成为16的倍数。解密后会删除多余的空格并返回明文。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

    什么是AES自己百度查下吧,直接上代码喽!

    

import base64

from Crypto import Random
from Crypto.Cipher import AES

"""
创建aes实例, 参数: key秘钥(16, 24, 32, 目前16就可以了); mode加密方式这里采用CBC(分组); iv位移, 使用自带AES.block_size代表16位
常见加密模式: CBC密码分组, CFB密码反馈, OFB输出反馈, ECB电码本(分段加密)
aes = AES.new(key, mode, iv)
aes.encrypt(plain_text) 加密
aes.decrypt(cipher_text) 解密
"""

class Encrypt:
"""AES加解密"""

    def __init__(self, key):
        self.key = key
        self.iv = Random.new().read(AES.block_size)
        self.mode = AES.MODE_CBC

    def encrypt(self, text):
        if len(text) % 16 != 0: #不是16的倍数,补足16的倍数
            text = text + abs(len(text) % 16 - 16) * '

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值