Я не могу получить тот же результат зашифрованного текста в JAVA из моего php-скрипта. Это мой php-код (клиентская сторона – моя сторона):
$input = 'my text to be encrypted'; $key = 'my key'; $size = mcrypt_get_block_size(MCRYPT_DES, 'ecb'); $input = pkcs5_pad($input, $size); $td = mcrypt_module_open(MCRYPT_DES, '', 'ecb', ''); $iv = mcrypt_create_iv (mcrypt_enc_get_iv_size($td), MCRYPT_RAND); mcrypt_generic_init($td, $key, $iv); $data = mcrypt_generic($td, $input); print base64_encode($data); function pkcs5_pad ($text, $blocksize) { $pad = $blocksize - (strlen($text) % $blocksize); return $text . str_repeat(chr($pad), $pad); }
Это базовый код JAVA (серверная сторона):
SecretKey key = new SecretKeySpec(keyBytes, "DES"); Cipher ecipher = Cipher.getInstance("DES/ECB/PKCS5Padding"); byte[] utf8 = str.getBytes("UTF8"); byte[] enc = ecipher.doFinal(utf8); // Encode bytes to base64 to get a string return new String(Base64Utils.encode(enc));
Я знаю, что в php есть проблема с заполнением, что делает разницу в моем результате. Не могу найти почему.
IV должен соответствовать тому, что использует java. Поскольку вы просто создаете случайный, он никогда не будет соответствовать. (Функция mcrypt_create_iv ())
Узнайте, что (если есть) использует java.