侯体宗的博客
  • 首页
  • Hyperf版
  • beego仿版
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

thinkphp微信开之安全模式消息加密解密不成功的解决办法

ThinkPHP  /  管理员 发布于 8年前   368

 ThinkPHP框架是国内比较流行的PHP框架之一,虽然跟国外的那些框架没法比,但优点在于,恩,中文手册很全面,在此不多说了。

使用thinkphp官方的WeChat包,使用不同模式可以成功,但是安全模式就是不行,现将分析解决结果做下记录。

 分析问题:

          解密微信服务器消息老是不成功,下载下微信公众平台官方给出的解密文件和WechatCrypt.class.php进行比对发现也没有问题。用file_put_contents函数保存下解密后的文件进行分析。发现官方包解密的xml不是标准的xml格式,所以simplexml_load_string函数无法处理。

/**   * 对密文进行解密   * @param string $encrypt 密文   * @return string     明文   */  public function decrypt($encrypt){    //BASE64解码    $encrypt = base64_decode($encrypt);    //打开加密算法模块    $td = mcrypt_module_open(MCRYPT_RIJNDAEL_128, '', MCRYPT_MODE_CBC, '');    //初始化加密算法模块    mcrypt_generic_init($td, $this->cyptKey, substr($this->cyptKey, 0, 16));    //执行解密    $decrypt = mdecrypt_generic($td, $encrypt);    //去除PKCS7补位    $decrypt = self::PKCS7Decode($decrypt, mcrypt_enc_get_key_size($td));    //关闭加密算法模块    mcrypt_generic_deinit($td);    mcrypt_module_close($td);    if(strlen($decrypt) < 16){      throw new \Exception("非法密文字符串!");    }    //去除随机字符串    $decrypt = substr($decrypt, 16);    //获取网络字节序    $size = unpack("N", substr($decrypt, 0, 4));    $size = $size[1];    //APP_ID    $appid = substr($decrypt, $size + 4);    //验证APP_ID    if($appid !== $this->appId){      throw new \Exception("非法APP_ID!");    }    //明文内容    $text = substr($decrypt, 4, $size);    return $text;  }  /**   * PKCS7填充字符   * @param string $text 被填充字符   * @param integer $size Block长度   */  private static function PKCS7Encode($text, $size){    //字符串长度    $str_size = strlen($text);    //填充长度    $pad_size = $size - ($str_size % $size);    $pad_size = $pad_size ? : $size;    //填充的字符    $pad_chr = chr($pad_size);    //执行填充    $text = str_pad($text, $str_size + $pad_size, $pad_chr, STR_PAD_RIGHT);    return $text;  }  /**   * 删除PKCS7填充的字符   * @param string $text 已填充的字符   * @param integer $size Block长度   */  private static function PKCS7Decode($text, $size){    //获取补位字符    $pad_str = ord(substr($text, -1));    if ($pad_str < 1 || $pad_str > $size) {      $pad_str= 0;    }       return substr($text, 0, strlen($text) - $pad_str);  }

解决方法:

          输出的xml文件是这样的

  <\/ToUserName>\n <\/FromUserName>\n <\/CreateTime>\n <\/MsgType>\n <\/Content>\n <\/MsgId>\n <\/xml>

       所以需要进行处理才能让simplexml_load_string处理

在输出的明文内容后面加上

 //明文内容     $text = substr($decrypt, , $size); //去掉多余的内容     $text=str_replace('<\/','\n','>', $text);     return $text;

安全模式就能正常使用了。

以上内容是小编给大家介绍的关于thinkphp微信开之安全模式消息加密解密不成功的解决办法,希望大家喜欢。

您可能感兴趣的文章:

  • thinkphp3.x中cookie方法的用法分析
  • thinkphp中session和cookie无效的解决方法
  • ThinkPHP的cookie和session冲突造成Cookie不能使用的解决方法
  • thinkphp5框架结合mysql实现微信登录和自定义分享链接与图文功能示例
  • thinkPHP5项目中实现QQ第三方登录功能
  • thinkPHP中U方法加密传递参数功能示例
  • ThinkPHP实现的rsa非对称加密类示例
  • thinkphp微信开发(消息加密解密)
  • PHP隐形一句话后门,和ThinkPHP框架加密码程序(base64_decode)
  • tp5框架使用cookie加密算法实现登录功能示例


  • 上一条:
    thinkphp微信开发(消息加密解密)
    下一条:
    最新制作ThinkPHP3.2.3完全开发手册
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • thinkphp + mongodb项目中数据加载慢问题分析及解决(0个评论)
    • thinkphp6框架中封装redis操作类(0个评论)
    • thinkphp6框架中实现定时任务功能流程步骤(0个评论)
    • Thinkphp5.1框架中实现Session+Redis会话共享流程步骤(0个评论)
    • TP5框架版本5.0.10安全漏洞根据官方补丁修复,也是本站安全漏洞修复(0个评论)
    • 近期文章
    • 在go+gin中使用"github.com/skip2/go-qrcode"实现url转二维码功能(0个评论)
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(0个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 欧盟关于强迫劳动的规定的官方举报渠道及官方举报网站(0个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf文件功能(0个评论)
    • Laravel从Accel获得5700万美元A轮融资(0个评论)
    • 在go + gin中gorm实现指定搜索/区间搜索分页列表功能接口实例(0个评论)
    • 在go语言中实现IP/CIDR的ip和netmask互转及IP段形式互转及ip是否存在IP/CIDR(0个评论)
    • PHP 8.4 Alpha 1现已发布!(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2016-10
    • 2017-07
    • 2017-08
    • 2017-09
    • 2017-10
    • 2017-12
    • 2018-01
    • 2018-02
    • 2020-03
    • 2021-07
    • 2021-12
    • 2022-05
    • 2022-06
    • 2022-09
    • 2023-01
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客