私のPHPスクリプトからJAVAの暗号化されたテキストと同じ結果を得ることはできません。 これは私のPHPコード(クライアント側 - 私の側)である:JAVA DES in 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のパディング問題があることを知っています私の結果の違い。 理由が見つかりません。
実際、ECBモードを使用しないでください。暗号化が壊れにくいためです。 IVでCBCモードを使用します。 (参照:http://en.wikipedia.org/wiki/Block_cipher_modes_of_operation) – Zarkonnen