ファイルを復号化するスクリプトを作成したいのですが、スクリプトを実行してこのメッセージを表示しようとすると、どうすれば修正できますか?
トレースバック(最後の最後の呼び出し):ファイル "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)"""
Crypto ++ wiki から。
ブロックサイズはAES :: BLOCKSIZEによって決定されます。 AESの場合、これは常に16バイトです。
AESはブロック暗号であり、16バイト(128ビット)ブロックで機能します。データは機能しません16バイトよりも小さいか大きい。小さいデータは16バイトになるまでpaddedにする必要があり、大きいデータは16バイトのブロックに分割する必要があります。
また、それを達成するのに役立つアルゴリズムがあります(暗号のブロックサイズよりも大きいデータで作業します)。これらのアルゴリズムは ブロック暗号の動作モード と呼ばれます。
これを見てください AESを使用して16バイト以上を暗号化する方法?
ValueError:入力文字列は長さが16の倍数でなければなりません
[〜#〜] aes [〜#〜] は128ビット(16文字)のブロックで機能するためです。これを修正するために padding を追加することを検討できます。
データサイズが大きくないの場合に、データを暗号化するときに使用できる小さなトリックを次に示します。
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
に元のプレーンテキストが含まれます。