本篇内容介绍了“Python用AES&SHA1PRNG算法进行加密与解密”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
python3 - 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)
“Python用AES&SHA1PRNG算法进行加密与解密”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注亿速云网站,小编将为大家输出更多高质量的实用文章!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。