<?php
/**
* AES/CBC/PKCS5Padding Encrypter
*
* @param $str
* @param $key
* @return string
*/
function encrypt($str, $key)
{
$zeroPack = pack('i*', 0);
$iv = str_repeat($zeroPack, 4);
mcrypt_create_iv(mcrypt_get_iv_size(MCRYPT_RIJNDAEL_128, MCRYPT_MODE_CBC), MCRYPT_RAND);
$encryptedStr = mcrypt_encrypt(
MCRYPT_RIJNDAEL_128,
hex2bin(md5($key)),
pkcs5_pad($str, mcrypt_get_block_size(MCRYPT_RIJNDAEL_128, MCRYPT_MODE_CBC)),
MCRYPT_MODE_CBC,
$iv)
;
return bin2hex($encryptedStr);
}
/**
* AES/CBC/PKCS5Padding Decrypter
*
* @param $encryptedStr
* @param $key
* @return string
*/
function decrypt($encryptedStr, $key)
{
$zeroPack = pack('i*', 0);
$iv = str_repeat($zeroPack, 4);
return pkcs5_unpad(mcrypt_decrypt(
MCRYPT_RIJNDAEL_128,
hex2bin(md5($key)),
hex2bin($encryptedStr),
MCRYPT_MODE_CBC,
$iv
));
}
function pkcs5_pad ($text, $blocksize)
{
$pad = $blocksize - (strlen($text) % $blocksize);
return $text . str_repeat(chr($pad), $pad);
}
function pkcs5_unpad($text)
{
$pad = ord($text{strlen($text)-1});
if ($pad > strlen($text)) return false;
if (strspn($text, chr($pad), strlen($text) - $pad) != $pad) return false;
return substr($text, 0, -1 * $pad);
}
$key = 'test-key';
$str = 'test str';
var_dump($str == decrypt(encrypt($str, $key), $key));
鉴于有同学提醒PHP的Mcrypt扩展不再维护,追加OpenSSL版本代码,更加简洁。
/**
* AES/CBC/PKCS5Padding Encrypter
*
* @param $str
* @param $key
* @return string
*/
function encryptNew($str, $key)
{
$zeroPack = pack('i*', 0);
$iv = str_repeat($zeroPack, 4);
return bin2hex(openssl_encrypt($str, 'AES-256-CBC', hex2bin(md5($key)), OPENSSL_RAW_DATA, $iv));
}
/**
* AES/CBC/PKCS5Padding Decrypter
*
* @param $encryptedStr
* @param $key
* @return string
*/
function decryptNew($encryptedStr, $key)
{
$zeroPack = pack('i*', 0);
$iv = str_repeat($zeroPack, 4);
return openssl_decrypt(hex2bin($encryptedStr), 'AES-256-CBC', hex2bin(md5($key)), OPENSSL_RAW_DATA, $iv);
}
AES/CBC/PKCS5Padding的PHP实现
最新推荐文章于 2025-10-29 09:52:33 发布
本文介绍了一种使用PHP实现AES/CBC/PKCS5Padding的加密和解密方法,提供了两种实现方式:一种是使用Mcrypt扩展,另一种是使用更简洁的OpenSSL扩展。代码示例展示了如何通过这些方法对字符串进行加密和解密。
1万+

被折叠的 条评论
为什么被折叠?



