入力の長さが BLOCK_SIZE の倍数でない場合に、パディング (pad
暗号化を行う場合) とパディングを解除する (復号化を行う場合)の 2 つの関数が必要になる場合があります。unpad
BS = 16
pad = lambda s: s + (BS - len(s) % BS) * chr(BS - len(s) % BS)
unpad = lambda s : s[:-ord(s[len(s)-1:])]
それで、キーの長さを尋ねていますか?キーを直接使用するのではなく、キーの md5sum を使用できます。
さらに、PyCrypto を使用した私の小さな経験によると、IV は入力が同じ場合に暗号化の出力を混同するために使用されるため、IV はランダムな文字列として選択され、暗号化出力の一部として使用されます。それを使用してメッセージを復号化します。
そして、これが私の実装です。それがあなたにとって役立つことを願っています:
import base64
from Crypto.Cipher import AES
from Crypto import Random
class AESCipher:
def __init__( self, key ):
self.key = key
def encrypt( self, raw ):
raw = pad(raw)
iv = Random.new().read( AES.block_size )
cipher = AES.new( self.key, AES.MODE_CBC, iv )
return base64.b64encode( iv + cipher.encrypt( raw ) )
def decrypt( self, enc ):
enc = base64.b64decode(enc)
iv = enc[:16]
cipher = AES.new(self.key, AES.MODE_CBC, iv )
return unpad(cipher.decrypt( enc[16:] ))