Ich kann nicht das gleiche Ergebnis von verschlüsseltem Text in JAVA von meinem PHP-Skript erhalten. Das ist mein PHP-Code (Client-Seite - meine Seite):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);
}
Dies ist die Basis JAVA-Code (Server-Seite):
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));
Ich weiß, ein padding Problem in PHP gibt es, dass die macht Unterschied in meinem Ergebnis. Kann nicht warum finden.
FYI, Sie sollten wirklich nicht EZB-Modus verwenden, da es die Verschlüsselung ziemlich trivial zu brechen macht. Verwenden Sie den CBC-Modus mit einem IV. (Siehe: http://en.wikipedia.org/wiki/Block_cipher_modes_of_operation) – Zarkonnen