0

as3cryptoで「無効なパディング値」というエラーが発生する原因は何ですか?

Error: PKCS#5:unpad: Invalid padding value. expected [153], found [25]
    at com.hurlant.crypto.symmetric::PKCS5/unpad()
    at com.hurlant.crypto.symmetric::CTRMode/decrypt()
    at com.hurlant.crypto.symmetric::SimpleIVMode/decrypt()
    at com.mycompany.myproject::Application$/decrypt()
    ... (followed by the rest of my application stack)

SimpleIVMode ラッパー クラスを使用して、暗号化されたデータの前に初期化ベクター (IV) が追加されていることを確認することで、以前にこれを解決したと思います。ただし、この場合、私はすでにそれを行っています。

Cryptoダウンロード サイズを最小限に抑えることが重要であるため、このクラスは使用していません。

何か案は?

私の抽象化コード(Applicationクラス内):

protected static var cipher:ICipher = 
    new SimpleIVMode(
        new CTRMode(
            new AESKey( Hex.toArray("53c12a8eb8612733ec817290580c3d") // not actual key
        ))
    );

public static function encrypt(d:ByteArray):ByteArray {
    d.position = 0;
    cipher.encrypt(d);
    d.position = 0;
    return d;
}

public static function decrypt(d:ByteArray):ByteArray {
    d.position = 0;
    cipher.decrypt(d); // THIS LINE THROWS
    d.position = 0;
    return d;
}

そのすべてd.position = 0が私のパラノイアです。

暗号化コード:

// we first have to serialize the object to a ByteArray, then encrypt that data.
var encryptedValue:ByteArray = new ByteArray();
encryptedValue.writeObject(objectToEncrypt);
encryptedValue.position = 0; // paranoia?
Application.encrypt(encryptedValue);
so.setProperty(key, encryptedValue); // save it in my SharedObject

エラーの原因となるコード:

var data:ByteArray = so.data[key]; // get the byte array out of storage.
trace(data.length); // Check that it's real... I get 553 bytes
Application.decrypt(data); // THIS LINE THROWS
4

1 に答える 1

0

SharedObjectのメモリサイズを拡張する必要があると思います。

so.flush(1000000000000000);
于 2010-09-01T03:44:28.720 に答える