5

js CryptoJS を使用して暗号化し、python crypto.Cipher を使用して復号化する際に問題が発生する

これはjsでの私の実装で、暗号化されたメッセージでivを追加し、base64でエンコードします

<script src="http://crypto-js.googlecode.com/svn/tags/3.1.2/build/rollups/aes.js"></script>
<script>
    var message='Secreat Message to Encrypt';
    var key = CryptoJS.enc.Hex.parse('824601be6c2941fabe7fe256d4d5a2b7');
    var iv  = CryptoJS.enc.Hex.parse('1011121314151617');

    var encrypted = CryptoJS.AES.encrypt(message, key, { iv: iv, mode: CryptoJS.mode.CBC });
    encrypted =encrypted.toString();


    encrypted = iv+encrypted;
    encrypted = btoa(encrypted);
    console.log('encrypted',encrypted );    
    alert(encrypted); 

   // var decrypted =  CryptoJS.AES.decrypt(encrypted, key, { iv: iv, mode: CryptoJS.mode.CBC });
   // console.log('decrypted', decrypted);
   //alert(decrypted.toString(CryptoJS.enc.Utf8));
</script>

そして、私が使用したaes暗号化と復号化のためのpythonスクリプトで

#!/usr/bin/python

import os, random, struct
from Crypto.Cipher import AES
from Crypto import Random
import base64
class AESCipher:
    def __init__(self, key):
        BS = 16
        self.pad = lambda s: s + (BS - len(s) % BS) * chr(BS - len(s) % BS)
        self.unpad = lambda s : s[0:-ord(s[-1])]
        self.key = self.pad(key[0:16])

    def encrypt(self, raw):
        raw = self.pad(raw)
        iv = "1011121314151617"
        cipher = AES.new(self.key, AES.MODE_CBC, iv)
        return base64.b64encode(iv + cipher.encrypt(raw))

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


def main():     

    cipher = AESCipher('824601be6c2941fabe7fe256d4d5a2b7')
    encrypteddata =cipher.encrypt(''Secreat Message to Encrypt'')
    print encrypteddata         

    decryptdata =cipher.decrypt(encrypteddata)
    print decryptdata 

main()

しかし、同じ iv、メッセージ、およびキーは、python と js で異なる暗号化されたメッセージを生成します。

Python の復号化と互換性を持つための JavaScript の問題は何ですか?

どちらも AES.MODE_CBC を使用し、両方とも Pkcs7 パディングを使用したと想定しています。ハードコーディングされたivは今のところランダムに生成されます

4

1 に答える 1

0

実際に AES のブロック サイズと同じ 16 バイトの IV を試してください。現在、16 進数で 8 バイトを指定しています。CBC モードでは、ブロック サイズと同じサイズの IV が必要であり、Python API が指定します (最終的なタイプミスを含む)。

他のすべてのモードでは、block_size バイトの長さでなければなりません。

上記のように、メソッドまたは (事前定義された) 定数を使用することをお勧めします。

于 2014-01-07T19:12:32.523 に答える