Python基于AES&SHA1PRNG 算法 加密与解密

因工作需要,需要对aes进行加解密,收集资料时从网上找到了核心写法代码,经小量修改满足了需求。

核心加、解密代码来自原文: https://blog.csdn.net/max229max/article/details/87639613

#!/usr/bin/python
# -*- coding: UTF-8 -*-
'''
python3 - AES SHA1PRNG 算法 加密 解密
注,需安装以下依赖库:
pip3 install pycryptodome
pip3 install Crypto
'''

from Crypto.Cipher import AES
import hashlib

BS = AES.block_size

def padding_pkcs5(value):
    return str.encode(value + (BS - len(value) % BS) * chr(BS - len(value) % BS))

# 将十进制转换为十六进制
def get_sha1prng_key(key):
    signature = hashlib.sha1(key.encode()).digest()
    signature = hashlib.sha1(signature).digest()
    return ''.join(['%02x' % i for i in signature]).upper()[:32]

# 加密
def encrypt(key:str,value:str) -> str:
    cryptor = AES.new(bytes.fromhex(key), AES.MODE_ECB)
    padding_value = padding_pkcs5(value)  # padding content with pkcs5
    ciphertext = cryptor.encrypt(padding_value)
    return ''.join(['%02x' % i for i in ciphertext]).upper()

# 解密
def decrypt(key:str, value:str) -> str:
    ''' AES/ECB/NoPadding decrypt '''
    key = bytes.fromhex(key)
    cryptor = AES.new(key, AES.MODE_ECB)
    ciphertext = cryptor.decrypt(bytes.fromhex(value))
    return padding_zero(str(ciphertext, "utf-8"))

# 字符串处理,过滤特殊字符
def padding_zero(value):
    list = []
    for c in value:
        # ascii码范围获取
        if ord(c) > 31 & ord(c) < 127:
            list.append(c)
    return ''.join(list)

if __name__ == '__main__':
    key = 'cce33fa1-9496-4796-8a32-f84e65dcb056'
    content = 'test_data_10086'
    edb = encrypt(get_sha1prng_key(key),content)
    print(content +'='+ edb)
    ddb = decrypt(get_sha1prng_key(key),edb)
    print(edb +'='+ ddb)
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值