python使用AES算法CBC模式加密,使用了偏移量,pkcs7padding

本文详细介绍了使用Python实现AES加密和解密的过程,包括环境搭建、代码解析及具体应用实例。通过PrpCrypt类,实现了对数据的PKCS7填充、加密、解密功能,并提供了完整的代码示例。

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

直接抛源代码
环境需求:
pip install pycryptodome

import base64
from cryptography.hazmat.primitives import padding
from cryptography.hazmat.primitives.ciphers import algorithms
from Crypto.Cipher import AES
from binascii import b2a_hex, a2b_hex


class PrpCrypt(object):

    def __init__(self, key,iv):
        self.key = key.encode('utf-8')
        self.iv = iv.encode('utf-8')
        self.mode = AES.MODE_CBC

    # 加密函数,如果text不足16位就用空格补足为16位,
    # 如果大于16当时不是16的倍数,那就补足为16的倍数。
    def encrypt(self, text):
        cryptor = AES.new(self.key, self.mode, self.iv)
        text = text.encode('utf-8')

        # 这里密钥key 长度必须为16(AES-128),
        # 24(AES-192),或者32 (AES-256)Bytes 长度
        # 目前AES-128 足够目前使用
        
        text=self.pkcs7_padding(text)


        self.ciphertext = cryptor.encrypt(text)

        # 因为AES加密时候得到的字符串不一定是ascii字符集的,输出到终端或者保存时候可能存在问题
        # 所以这里统一把加密后的字符串转化为16进制字符串
        return b2a_hex(self.ciphertext)

    @staticmethod
    def pkcs7_padding(data):
        if not isinstance(data, bytes):
            data = data.encode()

        padder = padding.PKCS7(algorithms.AES.block_size).padder()

        padded_data = padder.update(data) + padder.finalize()

        return padded_data

	@staticmethod
    def pkcs7_unpadding(padded_data):
        unpadder = padding.PKCS7(algorithms.AES.block_size).unpadder()
        data = unpadder.update(padded_data)
	
        try:
            uppadded_data = data + unpadder.finalize()
        except ValueError:
            raise Exception('无效的加密信息!')
        else:
            return uppadded_data


    # 解密后,去掉补足的空格用strip() 去掉
    def decrypt(self, text):
    	#偏移量'abcdefg'
        cryptor = AES.new(self.key, self.mode, b'abcd')
        plain_text = cryptor.decrypt(a2b_hex(text))
        # return plain_text.rstrip('\0')
        return bytes.decode(plain_text).rstrip('\0')
def encryption(password):
    pc = PrpCrypt('abc')  # 初始化密钥
    e = pc.encrypt("abcdefg").decode()  # 加密
    print(base64.b64encode(bytes().fromhex(e)))
只含加密
if __name__ == '__main__':
    changepassword("abcdefg")
加解密
if __name__ == '__main__':
	pc = PrpCrypt('0000000000000000','0000000000000000')  # 初始化密钥
    e = pc.encrypt("abcdefg")  # 加密
    d = pc.decrypt(e)  # 解密
    print("加密:", e.decode())
    print("解密:", d)

引用了:
https://blog.youkuaiyun.com/dawn_statdust/article/details/54893362
https://www.cnblogs.com/huangjianting/p/8666446.html
感谢两位博主

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值