簡體   English   中英

Python:雙向字母數字加密

[英]Python: Two-way Alphanumeric Encryption

我正在使用Python 2.7 我有一個字母數字字符串,我想對其執行加密/解密。 無論我做什么,都應該保持雙向,結果也應該是字母數字。

例如:

str = 'ma6546fbd'
encrypted_data = encrypt_function(str)
decrypted_data = decrypt_function(encrypted_data)
print decrypted_data # I get 'ma6546fbd'

我做了什么:

我寫了一個function

def xor_crypt_string(data, key):
    return ''.join(chr(ord(x) ^ ord(y)) for (x,y) in izip(data, cycle(key)))

這需要數據和一個鍵並返回結果,問題是它也包含特殊字符,我想避免。

如果您想進行嚴格的加密(讀不破),那么我會使用pycrypto的 AES 這樣的東西。

>>> from Crypto.Cipher import AES
>>> from Crypto import Random
>>> key = b'Sixteen byte key'
>>> iv = Random.new().read(AES.block_size)
>>> cipher = AES.new(key, AES.MODE_CFB, iv)
>>> msg = iv + cipher.encrypt(b'Attack at dawn')
>>> msg.encode("hex")
'e10e096aabff9db382abe8d704404995a7b64d72a4e1b9e5208912d206c4'

那是你的ASCII信息。 現在像這樣解碼消息

>>> recv='e10e096aabff9db382abe8d704404995a7b64d72a4e1b9e5208912d206c4'
>>> cipher.decrypt(recv.decode("hex"))[len(iv):]
'Attack at dawn'
>>> 

您自己構造的任何加密方法都容易被專家破壞,上面顯示的方法屬於該類別。

字母數字要求有多嚴格?

如何對現有加密功能的結果進行base64編碼? 您可能最終會遇到一些雜散的'='填充字符,但是可以修剪這些字符並計算並處理多余的填充。

def xor_crypt_string(plaintext, key):
    ciphertext = ''.join(chr(ord(x) ^ ord(y)) for (x,y) in izip(plaintext, cycle(key)))
    return ciphertext.encode('base64')

def xor_decrypt_string(ciphertext, key):
    ciphertext = ciphertext.decode('base64')
    return ''.join(chr(ord(x) ^ ord(y)) for (x,y) in izip(ciphertext, cycle(key)))

使用PyCryptodome ,它是PyCrypto的一個分支。

pip install pycryptodome

>>> from Crypto.Cipher import AES
>>> from Crypto import Random
>>> key = b'Sixteen byte key'
>>> iv = Random.new().read(AES.block_size)
>>> cipher = AES.new(key, AES.MODE_CFB, iv)
>>> msg = iv + cipher.encrypt(b'Attack at dawn')
>>> msg.hex()
'747a6a3c7357711773f4df5c3e8989dd055da5870d0bf7a967a5cd59ca98'

解密:

>>> encrypted_data = '747a6a3c7357711773f4df5c3e8989dd055da5870d0bf7a967a5cd59ca98'
>>> cipher = AES.new(key, AES.MODE_CFB, iv)
>>> cipher.decrypt(binascii.unhexlify(encrypted_data))[len(iv):]

注意:

密碼 object 是有狀態的:一旦你解密了一條消息,你就不能解密(或加密)另一條具有相同 object 的消息。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM