php aes cbc,php aes cbc

class aes_mcrypt {

private $hex_iv = '00000000000000000000000000000000'; # converted JAVA byte code in to HEX and placed it here

function __construct($key) {

$this->key = hash('sha256',$key, true);

}

function encrypt($str) {

$td = mcrypt_module_open(MCRYPT_RIJNDAEL_128, '', MCRYPT_MODE_CBC, '');

mcrypt_generic_init($td, $this->key, $this->hexToStr($this->hex_iv));

//$block = mcrypt_get_block_size(MCRYPT_RIJNDAEL_128, MCRYPT_MODE_CBC);

$block = mcrypt_enc_get_block_size($td);

$str = $this->addpadding($str,$block);

$encrypted = mcrypt_generic($td, $str);

mcrypt_generic_deinit($td);

mcrypt_module_close($td);

return base64_encode($encrypted);

}

function decrypt($code) {

$td = mcrypt_module_open(MCRYPT_RIJNDAEL_128, '', MCRYPT_MODE_CBC, '');

mcrypt_generic_init($td, $this->key, $this->hexToStr($this->hex_iv));

$str = mdecrypt_generic($td, base64_decode($code));

mcrypt_generic_deinit($td);

mcrypt_module_close($td);

return $this->strippadding($str);

}

/*

For PKCS7 padding

*/

private function addpadding($string, $blocksize = 16) {

$len = strlen($string);

$pad = $blocksize - ($len % $blocksize);

$string .= str_repeat(chr($pad), $pad);

return $string;

}

private function strippadding($string) {

$slast = ord(substr($string, -1));

$slastc = chr($slast);

$pcheck = substr($string, -$slast);

if (preg_match("/$slastc{" . $slast . "}/", $string)) {

$string = substr($string, 0, strlen($string) - $slast);

return $string;

} else {

return false;

}

}

public function hexToStr($hex)

{

$string='';

for ($i=0; $i 

{

$string .= chr(hexdec($hex[$i].$hex[$i+1]));

}

return $string;

}

}

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值