php 3des 向量,PHP 3DES 加解密(CBC模式,pkcs5padding填充)

1、前言:项目中接入第三方支付遇到3DES加密,以前也没用过,搜了好多,都不适用,各种不对,后来自己结合搜到的终于弄正确了,检测地址:http://tool.chacuo.net/crypt3des。

2、下面是类 适用(CBC加密模式,pkcs5padding填充)

20180111005302433071.png

20180111005302659642.png

代码:

/**

* @des 3DES加密算法,cbc模式,pkcs5Padding字符填充方式

*/

class TDEA

{

/**

* @param string $crypt 需要加密的字符串

* @param string $key 加密使用的密钥

* @param string $vi 加密使用的向量

* @return string $crypt 加密后的字符串

* @des 3DES加密

*/

final static public function encrypt($input, $key, $iv, $base64 = true) {

$size = 8;

$input = self::pkcs5_pad($input, $size);

$encryption_descriptor = mcrypt_module_open(MCRYPT_3DES, ‘‘, ‘cbc‘, ‘‘);

mcrypt_generic_init($encryption_descriptor, $key, $iv);

$data = mcrypt_generic($encryption_descriptor, $input);

mcrypt_generic_deinit($encryption_descriptor);

mcrypt_module_close($encryption_descriptor);

return base64_encode($data);

}

/**

* @param string $crypt 需要解密的字符串

* @param string $key 加密使用的密钥

* @param string $vi 加密使用的向量

* @return string $input 解密后的字符串

* @des 3DES解密

*/

final static public function decrypt($crypt, $key, $iv, $base64 = true) {

$crypt = base64_decode($crypt);

$encryption_descriptor = mcrypt_module_open(MCRYPT_3DES, ‘‘, ‘cbc‘, ‘‘);

mcrypt_generic_init($encryption_descriptor, $key, $iv);

$decrypted_data = mdecrypt_generic($encryption_descriptor, $crypt);

mcrypt_generic_deinit($encryption_descriptor);

mcrypt_module_close($encryption_descriptor);

$decrypted_data = self::pkcs5_unpad($decrypted_data);

return rtrim($decrypted_data);

}

final static private function pkcs5_pad($text, $blocksize) {

$pad = $blocksize - (strlen($text) % $blocksize);

return $text . str_repeat(chr($pad), $pad);

}

final static private function pkcs5_unpad($text) {

$pad = ord($text{strlen($text) - 1});

if ($pad > strlen($text)){

return false;

}

return substr($text, 0, -1 * $pad);

}

}

调用测试

$plaintext = "3DES加密测试";

$key = "r0uScmDuH5FLO37AJV2FN72J";// 加密所需的密钥

$iv = "1eX24DCe";// 初始化向量

$ciphertext = TDEA::encrypt($plaintext, $key, $iv);//加密

$plaintext2 = TDEA::decrypt($ciphertext, $key, $iv);//解密

echo "String: $plaintext
";

echo "Encrypted:";

echo $ciphertext;

echo"Decrypt: ";

echo $plaintext2;

检测地址:http://tool.chacuo.net/crypt3des

原文:http://www.cnblogs.com/yimingwang/p/7807880.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值