PHP实现DESede/ECB/PKCS5Padding加密算法兼容Java SHA1PRNG
在PHP中,可以使用openssl_encrypt
函数来实现DESede/ECB/PKCS5Padding
加密。由于PHP的mcrypt_*
系列函数已经在PHP 7.2.0中废弃,并且在PHP 7.3.0完全移除,以下是使用openssl_encrypt
函数的示例代码:
<?php
function desede_encrypt($data, $key) {
$cipher = 'des-ede3-ecb'; // DESede/ECB/NoPadding,PHP中没有PKCS5Padding,需要手动填充
$iv = openssl_random_pseudo_bytes(openssl_cipher_iv_length($cipher));
$encrypted = openssl_encrypt($data, $cipher, $key, OPENSSL_RAW_DATA, $iv);
// 使用PKCS5Padding填充
$block_size = openssl_cipher_iv_length($cipher);
$padded = pkcs5_pad($data, $block_size);
return base64_encode($encrypted);
}
function pkcs5_pad($text, $blocksize) {
$pad = $blocksize - (strlen($text) % $blocksize);
return $text . str_repeat(chr($pad), $pad);
}
$key = 'your-3-key'; // 24字节密钥
$plaintext = 'Your plaintext data';
$encrypted = desede_encrypt($plaintext, $key);
echo $encrypted;
?>
请注意,Java中的SHA1PRNG
是指使用了SHA1散列算法和Linux的/dev/random或/dev/urandom作为随机数源的加密算法。在PHP中,你可能需要使用random_bytes
或random_int
函数来获取随机数,但是PHP默认使用的是libc
的随机数生成器,与Java的SHA1PRNG
可能有所不同。如果需要确保与Java环境的加密结果一致,可能需要进一步调整或使用与Java环境相同的随机数源。
评论已关闭