PHP实现的DES加密解密类定义与用法示例


Posted in PHP onNovember 02, 2020

本文实例讲述了PHP实现的DES加密解密类定义与用法。分享给大家供大家参考,具体如下:

今天写App接口的时候需要传递加密数据给APP端,于是就写了下面的DES加密类,亲测正确代码如下

class CryptDes {
 function __construct(){
  $this->key = 'codelovers'; //密钥
  $this->iv = '15548632'; //偏移量
 }
 /*
  * 加密
  */
 function encrypt($input){
  $size = mcrypt_get_block_size(MCRYPT_DES,MCRYPT_MODE_CBC); //3DES加密将MCRYPT_DES改为MCRYPT_3DES
  $input = $this->pkcs5_pad($input, $size); //如果采用PaddingPKCS7,请更换成PaddingPKCS7方法。
  $key = str_pad($this->key,8,'0'); //3DES加密将8改为24
  $td = mcrypt_module_open(MCRYPT_DES, '', MCRYPT_MODE_CBC, '');
  if( $this->iv == '' )
  {
   $iv = @mcrypt_create_iv (mcrypt_enc_get_iv_size($td), MCRYPT_RAND);
  }
  else
  {
   $iv = $this->iv;
  }
  @mcrypt_generic_init($td, $key, $iv);
  $data = mcrypt_generic($td, $input);
  mcrypt_generic_deinit($td);
  mcrypt_module_close($td);
  $data = base64_encode($data);//如需转换二进制可改成 bin2hex 转换
  return $data;
 }
 /*
  * 解密
  */
 function decrypt($encrypted){
  $encrypted = base64_decode($encrypted); //如需转换二进制可改成 bin2hex 转换
  $key = str_pad($this->key,8,'0'); //3DES加密将8改为24
  $td = mcrypt_module_open(MCRYPT_DES,'',MCRYPT_MODE_CBC,'');//3DES加密将MCRYPT_DES改为MCRYPT_3DES
  if( $this->iv == '' )
  {
   $iv = @mcrypt_create_iv (mcrypt_enc_get_iv_size($td), MCRYPT_RAND);
  }
  else
  {
   $iv = $this->iv;
  }
  $ks = mcrypt_enc_get_key_size($td);
  @mcrypt_generic_init($td, $key, $iv);
  $decrypted = mdecrypt_generic($td, $encrypted);
  mcrypt_generic_deinit($td);
  mcrypt_module_close($td);
  $y=$this->pkcs5_unpad($decrypted);
  return $y;
 }
 function pkcs5_pad ($text, $blocksize) {
  $pad = $blocksize - (strlen($text) % $blocksize);
  return $text . str_repeat(chr($pad), $pad);
 }
 function pkcs5_unpad($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);
 }
 function PaddingPKCS7($data) {
  $block_size = mcrypt_get_block_size(MCRYPT_DES, MCRYPT_MODE_CBC);//3DES加密将MCRYPT_DES改为MCRYPT_3DES
  $padding_char = $block_size - (strlen($data) % $block_size);
  $data .= str_repeat(chr($padding_char),$padding_char);
  return $data;
 }
}

用法如下:

$str = '3water.com';
$des = new CryptDes();
$mres = $des->encrypt($str); //加密
echo $mres."<br/>";
$jres = $des->decrypt($mres); //解密
echo $jres."<br/>";

运行结果:

TxqbmhK86YWdTtTAQoDOqA==
3water.com

附录:php7 des加密解密

以下内容转自:https://blog.csdn.net/qq_35979073/article/details/81449590

1.在linux 环境中如果没有装encrypt扩展 或者php版本大于7.1不支持encrypt加密扩展

  可以使用openssl加密扩展

下面是封装的加密和解密的方法可直接调用

/**
 * des-ecb加密
 * @param string $data 要被加密的数据
 * @param string $key 加密密钥(64位的字符串)
 */
function des_ecb_encrypt($data, $key){
  return openssl_encrypt ($data, 'des-ecb', $key);
}
 
/**
 * des-ecb解密
 * @param string $data 加密数据
 * @param string $key 加密密钥
 */
function des_ecb_decrypt ($data, $key){
  return openssl_decrypt ($data, 'des-ecb', $key);
}

说明: $key 加密密钥(64位的字符串)  自己定义的

PHP 相关文章推荐
谈谈PHP语法(4)
Oct 09 PHP
php中curl使用指南
Feb 05 PHP
PHP输出九九乘法表代码实例
Mar 27 PHP
浅谈php+phpStorm+xdebug配置方法
Sep 17 PHP
详解PHP执行定时任务的实现思路
Dec 21 PHP
PHP使用socket发送HTTP请求的方法
Feb 14 PHP
Yii2学习笔记之汉化yii设置表单的描述(属性标签attributeLabels)
Feb 07 PHP
php生成图片缩略图功能示例
Feb 22 PHP
php简单生成一组与多组随机字符串的方法
May 09 PHP
Yii 2.0实现联表查询加搜索分页的方法示例
Aug 02 PHP
redis+php实现微博(一)注册与登录功能详解
Sep 23 PHP
如何解决PHP获取不到SESSION信息之一般情况
Oct 10 PHP
详解laravel安装使用Passport(Api认证)
Jul 27 #PHP
Ubuntu彻底删除PHP7.0的方法
Jul 27 #PHP
PHP实现的CURL非阻塞调用类
Jul 26 #PHP
PHP等比例压缩图片的实例代码
Jul 26 #PHP
PHP实现非阻塞模式的方法分析
Jul 26 #PHP
php实现等比例压缩图片
Jul 26 #PHP
PHP输出Excel PHPExcel的方法
Jul 26 #PHP
You might like
PHP flush()与ob_flush()的区别详解
2013/06/03 PHP
ThinkPHP关于session的操作方法汇总
2014/07/18 PHP
php实现数组按指定KEY排序的方法
2015/03/30 PHP
一文掌握PHP Xdebug 本地与远程调试(小结)
2019/04/23 PHP
php设计模式之正面模式实例分析【星际争霸游戏案例】
2020/03/24 PHP
Javascript学习笔记7 原型链的原理
2010/01/11 Javascript
js交换排序 冒泡排序算法(Javascript版)
2014/10/04 Javascript
js制作带有遮罩弹出层实现登录注册表单特效代码分享
2015/09/05 Javascript
javascript url几种编码方式详解
2016/06/06 Javascript
JavaScript实现汉字转换为拼音的库文件示例
2016/12/22 Javascript
基于javascript的Form表单验证
2016/12/29 Javascript
手机端js和html5刮刮卡效果
2020/09/29 Javascript
JS实现双击内容变为可编辑状态
2017/03/03 Javascript
Vue报错:Uncaught TypeError: Cannot assign to read only property’exports‘ of object’#‘的解决方法
2017/06/17 Javascript
jQuery Easyui Treegrid实现显示checkbox功能
2017/08/08 jQuery
简化版的vue-router实现思路详解
2018/10/19 Javascript
原生JavaScript写出Tabs标签页的实例代码
2020/07/20 Javascript
解决vue中的无限循环问题
2020/07/27 Javascript
[58:25]VP vs RNG 2019国际邀请赛小组赛 BO2 第一场 8.15
2019/08/17 DOTA
Python实现的使用telnet登陆聊天室实例
2015/06/17 Python
python difflib模块示例讲解
2017/09/13 Python
Python tornado队列示例-一个并发web爬虫代码分享
2018/01/09 Python
Python Json模块中dumps、loads、dump、load函数介绍
2018/05/15 Python
Python import与from import使用及区别介绍
2018/09/06 Python
python的几种矩阵相乘的公式详解
2019/07/10 Python
selenium+PhantomJS爬取豆瓣读书
2019/08/26 Python
Pytorch 高效使用GPU的操作
2020/06/27 Python
美国宠物商店:Wag.com
2016/10/25 全球购物
DJI大疆无人机官方商城:全球领先的无人飞行器研发和生产商
2016/12/21 全球购物
Hertz荷兰:荷兰和全球租车
2018/01/07 全球购物
IMPORT的选项IGNORE有什么作用?缺省是什么设置?
2015/09/17 面试题
写给女朋友的检讨书
2014/01/28 职场文书
注册资产评估专业求职信
2014/07/16 职场文书
2015社区爱国卫生工作总结
2015/04/21 职场文书
我的中国梦主题教育活动总结
2015/05/07 职场文书
法人身份证明书
2015/06/18 职场文书