2012-09-24 16 views
10

Ich habe versucht, AES CBC Entschlüsselung in Python zu implementieren. Da der verschlüsselte Text kein Vielfaches von 16 Byte ist, war ein Padding erforderlich. Ohne Polsterung, tauchte dieser FehlerAES Entschlüsselung Padding mit PKCS5 Python

„Typeerror: Odd-Zeichenfolge“

Aber ich konnte keine richtige Referenz für die Umsetzung PKCS5 in PyCrypto Python finden. Gibt es Befehle, dies zu implementieren? Danke

Nachdem ich in Marcus 'Vorschlag gesucht habe, habe ich das getan.

Mein Ziel ist eigentlich eine Hex-Nachricht (128bytes) mit diesem Code zu entschlüsseln. Die Ausgabe ist jedoch "?:", Was sehr klein ist und der Unpad-Befehl löscht diese Bytes. Dies ist der Code.

from Crypto.Cipher import AES 
BS = 16 
pad = lambda s: s + (BS - len(s) % BS) * chr(BS - len(s) % BS) 
unpad = lambda s : s[0:-ord(s[-1])] 

class AESCipher: 
    def __init__(self, key): 
    self.key = key 

    def encrypt(self, raw): 
     raw = pad(raw) 
     iv = raw[:16] 
     raw=raw[16:] 
     #iv = Random.new().read(AES.block_size) 
     cipher = AES.new(self.key, AES.MODE_CBC, iv) 
     return (iv + cipher.encrypt(raw)).encode("hex") 

    def decrypt(self, enc): 
     iv = enc[:16] 
     enc= enc[16:] 
     cipher = AES.new(self.key, AES.MODE_CBC, iv) 
     return unpad(cipher.decrypt(enc)) 

mode = AES.MODE_CBC 
key = "140b41b22a29beb4061bda66b6747e14" 
ciphertext = "4ca00ff4c898d61e1edbf1800618fb2828a226d160dad07883d04e008a7897ee2e4b7465d5290d0c0e6c6822236e1daafb94ffe0c5da05d9476be028ad7c1d81"; 
key=key[:32] 
decryptor = AESCipher(key) 
decryptor.__init__(key) 
plaintext = decryptor.decrypt(ciphertext) 
print plaintext 
+1

http://stackoverflow.com/questions/12524994/encrypt-decrypt-using-pycrypto-aes-256/12525165#12525165 können die Polsterung Funktionen in Antwort helfen :) – Marcus

Antwort

18

Sie müssen Ihren hexadezimalen Wert vor der Entschlüsselung dekodieren. Wenn Sie mit hexadezimierten Tasten arbeiten wollen, dekodieren Sie sie auch.

Hier sollte das funktionieren.

from Crypto.Cipher import AES 
from Crypto import Random 

BS = 16 
pad = lambda s: s + (BS - len(s) % BS) * chr(BS - len(s) % BS) 
unpad = lambda s : s[0:-ord(s[-1])] 

class AESCipher: 
    def __init__(self, key): 
     """ 
     Requires hex encoded param as a key 
     """ 
     self.key = key.decode("hex") 

    def encrypt(self, raw): 
     """ 
     Returns hex encoded encrypted value! 
     """ 
     raw = pad(raw) 
     iv = Random.new().read(AES.block_size); 
     cipher = AES.new(self.key, AES.MODE_CBC, iv) 
     return (iv + cipher.encrypt(raw)).encode("hex") 

    def decrypt(self, enc): 
     """ 
     Requires hex encoded param to decrypt 
     """ 
     enc = enc.decode("hex") 
     iv = enc[:16] 
     enc= enc[16:] 
     cipher = AES.new(self.key, AES.MODE_CBC, iv) 
     return unpad(cipher.decrypt(enc)) 

if __name__== "__main__": 
    key = "140b41b22a29beb4061bda66b6747e14" 
    ciphertext = "4ca00ff4c898d61e1edbf1800618fb2828a226d160dad07883d04e008a7897ee2e4b7465d5290d0c0e6c6822236e1daafb94ffe0c5da05d9476be028ad7c1d81" 
    key=key[:32] 
    decryptor = AESCipher(key) 
    plaintext = decryptor.decrypt(ciphertext) 
    print "%s" % plaintext 
+0

Diese **; ** am Ende von 'ciphertext = ...' sollte da wohl nicht sein ... – kravietz