web-dev-qa-db-ja.com

AES:入力文字列の長さは16の倍数である必要があります

ファイルを復号化するスクリプトを作成したいのですが、スクリプトを実行してこのメ​​ッセージを表示しようとすると、どうすれば修正できますか?

トレースバック(最後の最後の呼び出し):ファイル "F:\ bug_bounty\decrypt.py"、46行目、ファイル "F:\ bug_bounty\decrypt.py"、24行目、復号化ファイル "C:\ Python27\lib\site-packages\Crypto\Cipher\blockalgo.py "、行295、decrypt return self._cipher.decrypt(ciphertext)の値エラー:入力文字列の長さは16の倍数である必要があります

from Crypto.Hash import SHA256
from Crypto.Cipher import AES
import os
import random
import sys


def decrypt(key, filename):
    outFile = os.path.join(os.path.dirname(filename),
                           os.path.basename(filename[11:]))
    chunksize = 64 * 1024
    with open(filename, 'rb') as infile:
        filesize = infile.read(16)
        IV = infile.read(16)

        decryptor = AES.new(key, AES.MODE_CBC, IV)

        with open(outFile, 'wb') as outfile:
            while True:
                chunk = infile.read(chunksize)
                if len(chunk) == 0:
                    break

                outfile.write(decryptor.decrypt(chunk))

            outfile.truncate(int(filesize))


def allfiles():
    allFiles = []
    for (root, subfiles, files) in os.walk(os.getcwd()):
        for names in files:
            allFiles.append(os.path.join(root, names))

    return allFiles


password = 'M4st3rRul3zs'
files = allfiles();
for filename in files:
    if os.path.basename(filename).startswith("(encrypted)"):
       print "%s is already encrypted" %filename
       pass

    else:  
        decrypt(SHA256.new(password).digest(), filename)
        print "Done decrypting %s" %filename
        """os.remove(filename)"""
7
Aron Imperial

Crypto ++ wiki から。

ブロックサイズはAES :: BLOCKSIZEによって決定されます。 AESの場合、これは常に16バイトです。

AESはブロック暗号であり、16バイト(128ビット)ブロックで機能します。データは機能しません16バイトよりも小さいか大きい。小さいデータは16バイトになるまでpaddedにする必要があり、大きいデータは16バイトのブロックに分割する必要があります。

また、それを達成するのに役立つアルゴリズムがあります(暗号のブロックサイズよりも大きいデータで作業します)。これらのアルゴリズムは ブロック暗号の動作モード と呼ばれます。

これを見てください AESを使用して16バイト以上を暗号化する方法?

4
McGrady

ValueError:入力文字列は長さが16の倍数でなければなりません

[〜#〜] aes [〜#〜] は128ビット(16文字)のブロックで機能するためです。これを修正するために padding を追加することを検討できます。

2
Chankey Pathak

データサイズが大きくないの場合に、データを暗号化するときに使用できる小さなトリックを次に示します。

plaintext = "some text"
encryptor = AES.new(key, AES.MODE_CBC, iv)
ciphertext = encryptor.encrypt(plaintext*16)

これにより、入力データが16の倍数になることが保証されます。もちろん、復号化するときに元のデータを取得したいとします。

cipher = AES.new(key, AES.MODE_CBC, iv)
decrypttext = cipher.decrypt(ciphertext)
decrypttext = decrypttext[0:len(plaintext)]

これで、decrpyttextに元のプレーンテキストが含まれます。

0
Mayank Pathela