Python 3.5, PyCrypto 2.7a1, Fenster, RC2Wie entschlüsselt man einen RC2-Chiffretext?
Beispiel Chiffrierung:
print('Введите текс, который хотите зашифровать:')
text = input()
with open('plaintext.txt', 'w') as f:
f.write(text)
key = os.urandom(32)
with open('rc2key.bin', 'wb') as keyfile:
keyfile.write(key)
iv = Random.new().read(ARC2.block_size)
cipher = ARC2.new(key, ARC2.MODE_CFB, iv)
ciphertext = iv + cipher.encrypt(bytes(text, "utf-8"))
with open('iv.bin', 'wb') as f:
f.write(iv)
with open('ciphertext.bin', 'wb') as f:
f.write(ciphertext)
print(ciphertext.decode("cp1251"))
Und ich würde gerne wissen, wie kann ich diesen Text zu entschlüsseln, habe ich versucht, aber es nicht tun kann.
Mein Versuch zu entschlüsseln:
os.system('cls')
print('Дешифруем значит')
with open('ciphertext.bin', 'rb') as f:
ciphertext = f.read()
with open('rc2key.bin', 'rb') as f:
key = f.read()
with open('iv.bin', 'rb') as f:
iv = f.read()
ciphertext = ciphertext.decode('cp1251')
iv = iv.decode('cp1251')
text = ciphertext.replace(iv, '')
text = cipher.decrypt(text)
with open('plaintext.txt', 'w') as f:
f.write(text)
print(text.decode("ascii"))
Aber ich verstanden, dass ich Chiffre Variable benötigen, und ich kann es nicht .txt oder .bin-Datei speichern, so dass, warum ich um Hilfe zu bitten bin.
Ich kann hier nur den Verschlüsselungscode sehen. Bitte zeigen Sie ein [Minimales, vollständiges und verifizierbares Beispiel] (/ help/mcve) einschließlich des Fehlers, den Sie erhalten. Beachten Sie, dass Sie die * exact * gleichen Bytes des Schlüssels und des IV während der Entschlüsselung verwenden müssen. –
@ArtjomB. bearbeitet – Tukanoid