Подтвердить что ты не робот

Python: двухстороннее буквенно-цифровое шифрование

Я использую 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)))

Это берет данные и ключ и возвращает результат, проблема в том, что он включает специальные символы, которых я хочу избежать.

4b9b3361

Ответ 1

Если вы хотите серьезное шифрование (считайте нерушимым), я бы использовал 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'
>>> 

Любой метод шифрования, который вы составляете самостоятельно, будет легко разбит экспертом, и тот, который вы показали выше, попадает в эту категорию.

Ответ 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)))