Python:双向字母数字加密

Zai*_*han 13 python encryption

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

例如:

str = 'ma6546fbd'
encrypted_data = encrypt_function(str)
decrypted_data = decrypt_function(encrypted_data)
print decrypted_data # I get 'ma6546fbd'
Run Code Online (Sandbox Code Playgroud)

我做了什么:

我写了一个函数

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

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

Nic*_*ood 35

如果你想认真加密(读牢不可破的),那么我会使用AESpycrypto这样的事情.

>>> 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'
Run Code Online (Sandbox Code Playgroud)

这是你的ascii消息.现在解码这样的消息

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

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

  • 如果你只使用一次密钥,那么每条消息都有一个不同的密钥,你是对的.这是一次性垫.然而,一次性垫非常不方便,因为您需要存储与消息一样多的关键信息,并且需要事先与发送方和接收方达成一致!使用AES,您可以为每条消息使用相同的密钥,并确保(出于实际目的)没有人可以在没有密钥的情况下解密您的消息. (4认同)