我正在使用 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)))
这会获取数据和一个键并返回结果,问题是它也包含特殊字符,我想避免使用。
答案 0 :(得分:35)
如果您需要严格的加密(读取牢不可破),那么我会使用AES这样的pycrypto。
>>> 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'
>>>
您自己编写的任何加密方法都很容易被专家破解,而您上面显示的加密方法属于该类别。
答案 1 :(得分: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)))