2010-11-18 15 views
1

私の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のパディング問題があることを知っています私の結果の違い。 理由が見つかりません。

+0

実際、ECBモードを使用しないでください。暗号化が壊れにくいためです。 IVでCBCモードを使用します。 (参照:http://en.wikipedia.org/wiki/Block_cipher_modes_of_operation) – Zarkonnen

答えて

1

IVは、Javaが使用しているものと一致する必要があります。 ランダムなものを生成しているだけなので、決して一致しません。 (mcrypt_create_iv()関数)

Javaが使用するものがあれば、それを調べてください。

+0

あなたは 'getIV()'メソッドでそれを得ることができます。 –

+0

JAVAはnullを返します。私はPHPからIVを削除しようとしていますが、警告が表示されています - "空のIVを使用しようとしました"と結果はPHPから同じです。 – Adi