Невозможно обмениваться данными, зашифрованными с помощью AES-256, между Java и PHP

Моя проблема: то, что я шифрую на Java, я могу отлично расшифровать на Java, но PHP mcrypt не может расшифровать. То, что я шифрую с помощью mcrypt , я могу расшифровать с помощью mcrypt , но не могу в Java.

Я хочу отправлять и получать зашифрованные данные из приложения Java на страницу PHP, поэтому мне нужно, чтобы он был совместим.

Вот что у меня ...

JAVA ...

public static String crypt(String input, String key){
    byte[] crypted = null;
    try{
        SecretKeySpec skey = new SecretKeySpec(Base64.decodeBase64(key), "AES");
        Cipher cipher = Cipher.getInstance("AES/ECB/PKCS5Padding");
        cipher.init(Cipher.ENCRYPT_MODE, skey);
        crypted = cipher.doFinal(input.getBytes());
    }catch(Exception e){
    }
    return Base64.encodeBase64String(crypted);
}

public static String decrypt(String input, String key){
    byte[] output = null;
    try{
        SecretKeySpec skey = new SecretKeySpec(Base64.decodeBase64(key), "AES");
        Cipher cipher = Cipher.getInstance("AES/ECB/PKCS5Padding");
        cipher.init(Cipher.DECRYPT_MODE, skey);
        output = cipher.doFinal(Base64.decodeBase64(input));
    }catch(Exception e){
    }
    return new String(output);
}

Выполняется:

public static void main(String[] args) {
    String key = "Zvzpv8/PXbezPCZpxzQKzL/FeoPw68jIb+NONX/LIi8=";
    String data = "example";
    System.out.println(Cpt.decrypt(Cpt.crypt(data, key), key));
}

Вывод:

example

PHP ...

function getEncrypt($sStr, $sKey) {
    return base64_encode(
        mcrypt_encrypt(
            MCRYPT_RIJNDAEL_256, 
            $sKey,
            $sStr,
            MCRYPT_MODE_ECB
        )
    );
}

function getDecrypt($sStr, $sKey) {
    return mcrypt_decrypt(
        MCRYPT_RIJNDAEL_256, 
        $sKey, 
        base64_decode($sStr), 
        MCRYPT_MODE_ECB
    );
}

Выполняется:

$crypt = getDecrypt(getEncrypt($str, $key), $key);
echo "<p>Crypt: $crypt</p>";

Вывод:

Crypt: example�������������������������

Использование PHP для шифрования "примера" с ключом "Zvzpv8 / PXbezPCZpxzQKzL / FeoPw68jIb + NONX / LIi8 =" Я получаю "YTYhgp4zC + w5IsViTR5PUkHMX4i7JzvA6hoGYT1 =". Используя Java для шифрования того же самого с тем же ключом, я получаю "+ tdAZqTE7WAVPXhB3Tp5 + g ==".

Я кодирую и декодирую base64 в правильном порядке, и я протестировал совместимость кодирования и декодирования base64 между Java и PHP и работает.

12
задан Moshe Katz 23 December 2015 в 22:01
поделиться