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 相关文章推荐
第十四节 命名空间 [14]
Oct 09 PHP
PHP脚本的10个技巧(4)
Oct 09 PHP
也谈php网站在线人数统计
Apr 09 PHP
Windows PHP5和Apache的安装与配置
Jun 08 PHP
PHP GD 图像处理组件的常用函数总结
Apr 28 PHP
php 安全过滤函数代码
May 07 PHP
深入php中var_dump方法的使用详解
Jun 24 PHP
php调用MySQL存储过程的方法集合(推荐)
Jul 03 PHP
php环境套包 dedeampz 伪静态设置示例
Mar 26 PHP
php从memcache读取数据再批量写入mysql的方法
Dec 29 PHP
php实现往pdf中加数字签名操作示例【附源码下载】
Aug 07 PHP
PHP单例模式模拟Java Bean实现方法示例
Dec 07 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
域名查询代码公布
2006/10/09 PHP
PHP 类型转换函数intval
2009/06/20 PHP
php网站被挂木马后的修复方法总结
2014/11/06 PHP
Laravel 中使用简单的方法跟踪用户是否在线(推荐)
2019/10/30 PHP
js加解密 脚本解密
2008/02/22 Javascript
js特效,页面下雪的小例子
2013/06/17 Javascript
JS 操作Array数组的方法及属性实例解析
2014/01/08 Javascript
如何正确使用javascript 来进行我们的程序开发
2014/06/23 Javascript
使用AngularJS来实现HTML页面嵌套的方法
2015/06/17 Javascript
JavaScript中var关键字的使用详解
2015/08/14 Javascript
详解angular ui-grid之过滤器设置
2017/06/07 Javascript
利用HBuilder打包前端开发webapp为apk的方法
2017/11/13 Javascript
vuex的简单使用教程
2018/02/02 Javascript
security.js实现的RSA加密功能示例
2018/06/06 Javascript
如何为vuex实现带参数的 getter和state.commit
2019/01/04 Javascript
layer.js之回调销毁对话框的例子
2019/09/11 Javascript
解决layui调用自定义方法提示未定义的问题
2019/09/14 Javascript
ES6使用新特性Proxy实现的数据绑定功能实例
2020/05/11 Javascript
Vue使用轮询定时发送请求代码
2020/08/10 Javascript
[02:18]DOTA2英雄基础教程 育母蜘蛛
2014/01/20 DOTA
Python对象的深拷贝和浅拷贝详解
2014/08/25 Python
PYTHON 中使用 GLOBAL引发的一系列问题
2016/10/12 Python
python3下实现搜狗AI API的代码示例
2018/04/10 Python
在Pycharm中设置默认自动换行的方法
2019/01/16 Python
将Pytorch模型从CPU转换成GPU的实现方法
2019/08/19 Python
django框架中间件原理与用法详解
2019/12/10 Python
python实现银行实战系统
2020/02/26 Python
python环境搭建和pycharm的安装配置及汉化详细教程(零基础小白版)
2020/08/19 Python
总经理助理职责
2014/02/04 职场文书
买卖协议书范本
2014/04/21 职场文书
客户经理竞聘演讲稿
2014/05/15 职场文书
计算机专业自荐信范文
2015/03/26 职场文书
2016年社区文体活动总结
2016/04/06 职场文书
Python time库的时间时钟处理
2021/05/02 Python
关于JavaScript回调函数的深入理解
2021/06/27 Javascript
微软Win11什么功能最惊艳? Windows11新功能特性汇总
2021/11/21 数码科技