怎么给网站 做排名,wordpress仿魔客吧,小视频解析网站怎么做,怎么优化自己网站讲道理#xff0c;一提到3DES算法#xff0c;首先想到的是要和java做交互了
现在3DES已经渐渐被抛弃了#xff0c;尤其是ECB加密模式使用的更少了#xff0c;但是没办法#xff0c;业务需要#xff0c;合作方用的是他#xff0c;你头再铁也不能怎样#xff0c;那就扒扒…讲道理一提到3DES算法首先想到的是要和java做交互了
现在3DES已经渐渐被抛弃了尤其是ECB加密模式使用的更少了但是没办法业务需要合作方用的是他你头再铁也不能怎样那就扒扒文档咯
网上完整的php实现以经不多了CBC加密模式居多所以我参考了好几篇文章整理了一个class出来共享上来避免后来人踩坑
感谢前人的整理总结
PHP版3DES加解密类更新成PKCS5填充模式 http://blog.163.com/hui\_san/blog/static/5710286720103169370195/
java和php对等的3DES加密算法http://jamie-wang.iteye.com/blog/1604596
JAVA和PHP通用的加解密整理版http://www.blogjava.net/qileilove/archive/2013/09/16/404111.html
在线测试网址 http://tool.chacuo.net/crypt3des
?php
/*** Created by PhpStorm.* User: KeenSting* Date: 2017/11/23* Time: 下午2:28* Name: 梁小苍* Phone: 13126734215* QQ: 707719848* File Description: 3DES_ECB_PKCS5Padding*/
class TripleDesEcb{/**加密* param $text string 文本内容* param $key string 秘钥 max 24* return string*/public function encrypt($text,$key){$iv mcrypt_create_iv(mcrypt_get_iv_size(MCRYPT_TRIPLEDES,MCRYPT_MODE_ECB), MCRYPT_RAND);$text $this-pkcs5Pad($text);$td mcrypt_module_open(MCRYPT_3DES,,MCRYPT_MODE_ECB,);mcrypt_generic_init($td,$key,$iv);$data base64_encode(mcrypt_generic($td, $text));mcrypt_generic_deinit($td);mcrypt_module_close($td);print_r($data);return $data;}/**解密* param $text* param $key*/public function decrypt($text,$key){$iv mcrypt_create_iv(mcrypt_get_iv_size(MCRYPT_TRIPLEDES,MCRYPT_MODE_ECB), MCRYPT_RAND);$td mcrypt_module_open(MCRYPT_3DES, , MCRYPT_MODE_ECB, );mcrypt_generic_init($td, $key, $iv);$data $this-pkcs5UnPad(mdecrypt_generic($td, base64_decode($text)));mcrypt_generic_deinit($td);mcrypt_module_close($td);print_r($data);}/*** param $text* return string*/private function pkcs5Pad($text){$pad 8 - (strlen($text) % 8);return $text . str_repeat(chr($pad), $pad);}/*** param $text* return bool|string*/private function pkcs5UnPad($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);}
}
//test
$a new TripleDesEcb();
$r $a-encrypt(keensting,AA190CD754A89EF100190CD754A89EF1);
$a-decrypt($r,AA190CD754A89EF100190CD754A89EF1);
//测试的加密结果经过base64编码后为juyYkxc6BYm3p8QQdvXIg解密即可得到原文对称加密算法的加密和解密用的是同一个类