15

我正在使用Python 2.7。我有一个字母数字字符串,我想对其执行加密/解密。无论我做什么都应该保持双向,结果也应该是字母数字。

例如:

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

我做了什么:

我写了一个函数

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

这需要数据和一个键并返回结果,问题是它也包含特殊字符,我想避免这种情况。

4

3 回答 3

39

如果您想要严格的加密(读取牢不可破),那么我会使用来自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'
>>> 

您自己编写的任何加密方法都将很容易被专家破解,而您上面展示的加密方法属于该类别。

于 2012-06-21T06:47:27.607 回答
2

字母数字要求有多严格?

对现有加密功能的结果进行 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)))
于 2012-06-21T06:48:11.600 回答
0

使用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):]

注意:

密码对象是有状态的:一旦您解密了一条消息,您就无法解密(或加密)具有相同对象的另一条消息。

于 2022-02-23T14:28:58.153 回答