PHP中的3DES加密解密可以使用mcrypt扩展库实现。下面是一个使用3DES ECB模式进行加密解密的示例代码:
```php
// 加密函数
function encrypt($data, $key) {
$key = substr($key, 0, 24);
$data = pkcs5_pad($data, 8);
$mcrypt = mcrypt_module_open('tripledes', '', 'ecb', '');
$iv = mcrypt_create_iv(mcrypt_enc_get_iv_size($mcrypt), MCRYPT_RAND);
mcrypt_generic_init($mcrypt, $key, $iv);
$encrypted = mcrypt_generic($mcrypt, $data);
mcrypt_generic_deinit($mcrypt);
mcrypt_module_close($mcrypt);
return base64_encode($encrypted);
}
// 解密函数
function decrypt($data, $key) {
$key = substr($key, 0, 24);
$data = base64_decode($data);
$mcrypt = mcrypt_module_open('tripledes', '', 'ecb', '');
$iv = mcrypt_create_iv(mcrypt_enc_get_iv_size($mcrypt), MCRYPT_RAND);
mcrypt_generic_init($mcrypt, $key, $iv);
$decrypted = mdecrypt_generic($mcrypt, $data);
mcrypt_generic_deinit($mcrypt);
mcrypt_module_close($mcrypt);
return pkcs5_unpad($decrypted);
}
// PKCS5填充函数
function pkcs5_pad($data, $blocksize) {
$pad = $blocksize - (strlen($data) % $blocksize);
return $data . str_repeat(chr($pad), $pad);
}
// PKCS5去填充函数
function pkcs5_unpad($data) {
$pad = ord($data[strlen($data) - 1]);
if ($pad > strlen($data)) {
return false;
}
if (strspn($data, chr($pad), strlen($data) - $pad) != $pad) {
return false;
}
return substr($data, 0, -1 * $pad);
}
// 使用示例
$key = '123456789012345678901234';
$data = 'Hello World!';
$encrypted = encrypt($data, $key);
echo '加密后的数据:' . $encrypted . "\n";
$decrypted = decrypt($encrypted, $key);
echo '解密后的数据:' . $decrypted . "\n";
```
在上述代码中,encrypt()函数用于加密数据,decrypt()函数用于解密数据。其中,$data表示待加密的数据,$key表示加密密钥。在加密过程中,需要先对数据进行PKCS5填充。解密时,需要先将密文进行base64解码,然后再进行解密操作。