zoukankan      html  css  js  c++  java
  • 微信二次分享报错invalid signature问题及解决方法

    基于微信公众号开发的h5页面(使用jssdk接口),由用户A分享给用户B,用户B再次分享这个页面时,不能成功分享。问题出在用户B收到的分享链接与用户A打开的链接不同

    A用户的链接为

    http://test.com/test.html

    B用户收到的连接

    http://test.com/test.html&from=singlemessage

    from=singlemessage是微信客户端为了区分分享来源再链接后自动添加的标记,再次分享时,需要在js代码中对自动获取的连接进行encodeURIComponent处理,后台再对收到的url进行urldecode处理。

    js与php示例代码如下:

    注意ajax,用的post,用get据说不用转义(get方式本人未做测试)

    function share(){
      var nowurl     = window.location.href;
      var nowurlo   = nowurl.split('&')[0];
      $.ajax({
        type     : "post",
        url     : "***********************", //后端接口
        dataType   : "json",
        data     : { 'url': encodeURIComponent(nowurl) }, // 注意此处对nowurl进行encode;
        success   : function (data) {
          wx.config({
                debug    : false,        //调试模式
                appId    : data.appId,      //公众号appid
                timestamp  : data.timestamp,    //时间戳
                nonceStr   : data.noncestr,    //生成签名的随机串
                signature  : data.signature,    //签名
                jsApiList  : [
                  'updateAppMessageShareData',
                  'updateTimelineShareData',
                  'onMenuShareAppMessage',
                  'onMenuShareTimeline',
                  'chooseWXPay',
                  'showOptionMenu',
                  "hideMenuItems",
                  "showMenuItems",
                  "onMenuShareTimeline",
                  'onMenuShareAppMessage',
              ] // 必填,需要使用的JS接口列表
          });
          wx.ready(function () {  //需在用户可能点击分享按钮前就先调用
            wx.updateAppMessageShareData({ 
              title  : '', // 分享标题
              desc   : '', // 分享描述
              link   : nowurlo, // 自动获取(上面js代码中)
              imgUrl  : '', // 分享图标
              success : function () {
              }
            });
            wx.updateTimelineShareData({ 
              title   : '', // 分享标题
              link   : nowurlo, 自动获取(上面js代码中)
              imgUrl  : '', // 分享图标
              success  : function () {
              },
            });
          });
          
        }
      });
    }
    
    public function generateSignature(){
       $timestamp           = time();
       $jsapiTicket          = ;//此处获取jsapi_ticket
       $noncestr           = md5(uniqid(microtime(true),true));//我用的noncestr
       $url              = urldecode(I('post.url'));
       $signature           = sha1('jsapi_ticket=' . $jsapiTicket . '&noncestr=' . $noncestr . '×tamp=' . $timestamp . '&url=' . $url);
       $shareConfig['appId']     = '';//此处为appId
       $shareConfig['timestamp']   = $timestamp;
       $shareConfig['noncestr']    = $noncestr;
       $shareConfig['signature']   = $signature;
       $shareConfig['url']      = $url;
       echo json_encode($shareConfig);
     }
    
  • 相关阅读:
    【WPF/WAF】使用System.Windows.Interactivity交互事件
    【Linux/CentOS】Boolean ftp_home_dir is not defined
    【笔记】使用Token做验证
    【笔记】什么是跨域请求/访问?
    MongoDB优化与一些需要注意的细节
    MongoDB中聚合工具Aggregate等的介绍与使用
    MongoDB中MapReduce介绍与使用
    Centos下MongoDB的安装与配置
    PHP使用header方式实现文件下载
    关于redis中SDS简单动态字符串
  • 原文地址:https://www.cnblogs.com/phpfangzhan/p/12530474.html
Copyright © 2011-2022 走看看