php aes padding,php实现AES/CBC/PKCS5Padding加密解密(又叫:对称加密)

class MagicCrypt {

private $iv = "0102030405060708";//密钥偏移量IV,可自定义

private $encryptKey = "自定义16位长度key";//AESkey,可自定义

//加密

public function encrypt($encryptStr) {

$localIV = $this->iv;

$encryptKey = $this->encryptKey;

//Open module

$module = mcrypt_module_open(MCRYPT_RIJNDAEL_128, '', MCRYPT_MODE_CBC, $localIV);

//print "module = $module
" ;

mcrypt_generic_init($module, $encryptKey, $localIV);

//Padding

$block = mcrypt_get_block_size(MCRYPT_RIJNDAEL_128, MCRYPT_MODE_CBC);

$pad = $block - (strlen($encryptStr) % $block); //Compute how many characters need to pad

$encryptStr .= str_repeat(chr($pad), $pad); // After pad, the str length must be equal to block or its integer multiples

//encrypt

$encrypted = mcrypt_generic($module, $encryptStr);

//Close

mcrypt_generic_deinit($module);

mcrypt_module_close($module);

return base64_encode($encrypted);

}

//解密

public function decrypt($encryptStr) {

$localIV = $this->iv;

$encryptKey = $this->encryptKey;

//Open module

$module = mcrypt_module_open(MCRYPT_RIJNDAEL_128, '', MCRYPT_MODE_CBC, $localIV);

//print "module = $module
" ;

mcrypt_generic_init($module, $encryptKey, $localIV);

$encryptedData = base64_decode($encryptStr);

$encryptedData = mdecrypt_generic($module, $encryptedData);

return $encryptedData;

}

}

$encryptString = 'gz1DR+BsCzQe55HFdq1IiQ==';

$encryptObj = new MagicCrypt();

$result = $encryptObj->encrypt($encryptString);//加密结果

$decryptString = $decryptString = $encryptObj->decrypt($result);//解密结果

echo $result . "
";

echo $decryptString . "
";

?>

发现 mark app的加密用的这个方式,找了一个对应的,发现没问题

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值