您好,登錄后才能下訂單哦!
本篇內容介紹了“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進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。