php中实现3DES算法(ECB加密模式PKCS5Padding填充)
2017-11-23 15:43
896 查看
讲道理,一提到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
废话不多说直接上代码
测试的加密结果经过base64编码后为:juyYkxc6B+Ym3p8QQdvXIg==,解密即可得到原文(对称加密算法的加密和解密用的是同一个类)
现在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编码后为:juyYkxc6B+Ym3p8QQdvXIg==,解密即可得到原文(对称加密算法的加密和解密用的是同一个类)
相关文章推荐
- Java版适用于PHP版3DES加密解密(PHP语言开发的MCRYPT_3DES算法、MCRYPT_MODE_ECB模式、PKCS7填充方式)
- php 实现RIJNDAEL_128加密(CBC模式,PKCS7填充)
- PHP对接java的AES/ECB/PKCS5Padding加密方式
- java/php对应的AES/CBC/PKCS5Padding模式 加密解密
- JS 和 JAVA 实现 aes(AES/CBC/PKCS5Padding) 加密
- java加密之AES/ECB/PKCS5Padding
- PHP 3DES加密 与JAVA通用 加密模式:ECB
- DES_ECB模式加密C++实现
- node.js AES/ECB/PKCS5Padding 与其他语言的加密解密通用
- php 与 CPP 共用aes,ecb模式加密
- node.js AES/ECB/PKCS5Padding 与其他语言的加密解密通用
- DES ECB 模式 JAVA PHP C# 实现 加密 解密 兼容
- java实现基于PKCS5Padding填充方式的AES加解密
- PHP和Java AES 128 ECB 加解密(PKCS5Padding)
- AES128 ECB加密pkcs5padding补码
- AES/ECB/PKCS5Padding/PKCS7Padding 128位密钥(带密钥补位功能)加密解密
- JAVA DES加密(DES/ECB/PKCS5Padding)和C#加密对应设置
- AES/CBC/PKCS5Padding的PHP实现
- php实现 DES/CBC/PCCS5padding 加解密模式
- AES加密(AES/ECB/PKCS5Padding)key UTF8 取前十六个字节