微信jssdk调用php实现代码(解决二次分享失败问题)与逻辑梳理

微信jssdk调用

在网页中调用微信jssdk能够实现:

1.使用拍照、选图、语音、位置等手机系统的能力。
2.使用微信分享、扫一扫、卡券、支付等微信特有的能力。

调用步骤

1.使用微信测试账号,需要关注测试账号对应公众号,测试页面别人想要浏览,同样需要关注测试公众号

2.接口配置信息,填写url来响应微信发送的Token验证。

token处填写你自己设定的token值

<?php
$nonce     = $_GET['nonce'];
$token     = '你设定的token';
$timestamp = $_GET['timestamp'];
$echostr   = $_GET['echostr'];
$signature = $_GET['signature'];
//形成数组,然后按字典序排序
$array = array();
$array = array($nonce, $timestamp, $token);
sort($array);
//拼接成字符串,sha1加密 ,然后与signature进行校验
$str = sha1( implode( $array ) );
if( $str == $signature && $echostr ){
       //第一次接入weixin api接口的时候
       echo  $echostr;
       exit;
}

3.JS接口安全域名,设置完成后,即可在该域名下调用微信的jssdk。

域名与url:域名对应ip地址,一般到.com .net .org .cn就结束了,url是网络资源统一定位符,用来定位网页与文件,简单点url=网络传输协议+ip或域名 + 端口号 + 资源位置 + 参数 + 锚点

4.在服务器端实现签名算法,生成签名的逻辑:
(1)通过id与serect获得token;

(2)通过token获得tikect;

ps:由于token和tikect存在有效期且有访问次数限制,所以需要保存在本地,并定时更新。
这里采用保存在文件的方式,需要在网页同级目录下创wechat_token.txt与wechat_ticket.txt两个文件。

(3)将ticket与当前时间戳timestamp,随机数noncestr,url,按一定顺序排列成字符串
注意:在排列过程中不要使用url转义,如将&转义为&amp;(带分号),浏览器会正确识别,但服务器不行,会导致加密出来的结果不一样

(4)通过sha1加密这个字符串,生成签名,推荐通过微信签名校验工具验证签名是否正确

5.在需要调用jssdk的网页中,通过config接口注入权限验证,微信会通过你填写的id,随机数,时间戳去生成签名,再与你注入的本地生成的签名进行比对。
备注:网页经微信分享给朋友或朋友圈后,微信会在网页url后加渠道标记,可能导致二次分享失败,在代码中已给出解决方法

6.调用你需要的接口,有的接口如分享给好友,需要在页面加载时就调用好,需写在ready函数中

代码复制就能用,在网页同级目录下创wechat_token.txt与wechat_ticket.txt两个文件,需要填写的已经用中文标注了

<?php

// 微信 JS 接口签名校验工具: https://mp.weixin.qq.com/debug/cgi-bin/sandbox?t=jsapisign
$appid = '你自己的id';
$secret = '你自己的serect';


// 获取token,并保存在文件夹中
$token_data = file_get_contents('wechat_token.txt');
if (!empty($token_data)) {
    $token_data = json_decode($token_data, true);
}

$time  = time() - $token_data['time'];
if ($time > 3600) {
    $token_url = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid={$appid}&secret={$secret}";
    $token_res = https_request($token_url);
    $token_res = json_decode($token_res, true);
    $token = $token_res['access_token'];

    $data = array(
        'time' =>time(),
        'token' =>$token
    );
    $res = file_put_contents('wechat_token.txt', json_encode($data));
    if ($res) {
        echo '更新 token 成功';
    }
} else {
    $token = $token_data['token'];
}


// 获取ticket,并保存在文件夹中
$ticket_data = file_get_contents('wechat_ticket.txt');
if (!empty($ticket_data)) {
    $ticket_data = json_decode($ticket_data, true);
}

$time  = time() - $ticket_data['time'];
if ($time > 3600) {
    $ticket_url = "https://api.weixin.qq.com/cgi-bin/ticket/getticket?access_token={$token}&type=jsapi";
    $ticket_res = https_request($ticket_url);
    $ticket_res = json_decode($ticket_res, true);
    $ticket = $ticket_res['ticket'];

    $data = array(
        'time'    =>time(),
        'ticket'  =>$ticket
    );
    $res = file_put_contents('wechat_ticket.txt', json_encode($data));
    if ($res) {
        echo '更新 ticket 成功';
    }
} else {
    $ticket = $ticket_data['ticket'];
}


// 进行sha1签名
$timestamp = time();

$nonceStr = createNonceStr();


// 注意 URL 建议动态获取(也可以写死),我这里用的写死.
//$protocol = (!empty($_SERVER['HTTPS']) && $_SERVER['HTTPS'] !== 'off' || $_SERVER['SERVER_PORT'] == 443) ? "https://" : "http://";
//$url = "$protocol$_SERVER[HTTP_HOST]$_SERVER[REQUEST_URI]"; // 调用JSSDK的页面地址
$url= "你自己要调用微信jssdk的网页url";

$str = "jsapi_ticket={$ticket}&noncestr={$nonceStr}&timestamp={$timestamp}&url={$url}";


$sha_str = sha1("$str");

//echo "$sha_str,$str";


function createNonceStr($length = 16) {
    $chars = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789";
    $str = "";
    for ($i = 0; $i < $length; $i++) {
      $str .= substr($chars, mt_rand(0, strlen($chars) - 1), 1);
    }
    return $str;
}


/**
 * 模拟 http 请求
 * @param  String $url  请求网址
 * @param  Array  $data 数据
 */
function https_request($url, $data = null){
    // curl 初始化
    $curl = curl_init();

    // curl 设置
    curl_setopt($curl, CURLOPT_URL, $url);
    curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, FALSE);
    curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, FALSE);

    // 判断 $data get  or post
    if ( !empty($data) ) {
        curl_setopt($curl, CURLOPT_POST, 1);
        curl_setopt($curl, CURLOPT_POSTFIELDS, $data);
    }

    curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);

    // 执行
    $res = curl_exec($curl);
    curl_close($curl);
    return $res;
}

?>




<html>
<head>
  <title></title>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
</head>
<body>
   <h1 onclick="test()">扫一扫</h1>
    
    <script type="text/javascript" src="https://res.wx.qq.com/open/js/jweixin-1.2.0.js"></script>
    <script type="text/javascript">
    //微信二次分享会给你的url加上后缀,通过下面函数,将后缀去掉
        function getQueryString(name) {//根据字段看网址是否拼接&字符串
          var reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)", "i");
          var r = window.location.search.substr(1).match(reg);
          if (r != null)
              return unescape(r[2]);
          return null;
        }
        var from = getQueryString('from');
        var appinstall = getQueryString('appinstall');
        var sec = getQueryString('sec');
        var timekey = getQueryString('timekey');
      
        if(from || appinstall || sec || timekey){//假如拼接上了
            window.location.href ="你自己要调用微信jssdk的网页url"
        }
       var url = (window.location.href).split('#')[0];
        wx.config({
            debug: true, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。
            appId: '<? echo $appid ?>', // 必填,公众号的唯一标识
            timestamp: <? echo $timestamp ?>, // 必填,生成签名的时间戳
                nonceStr: '<? echo $nonceStr ?>', // 必填,生成签名的随机串
                signature: '<? echo $sha_str ?>',// 必填,签名
            jsApiList: ['scanQRCode','onMenuShareAppMessage', 'onMenuShareTimeline'] // 必填,需要使用的JS接口列表,我调用的扫一扫与分享给朋友
        });

        wx.ready(function () {
        
        wx.checkJsApi({
            jsApiList: ['onMenuShareAppMessage', 'onMenuShareTimeline','scanQRCode'],
            success: function (res) {JSON.stringify(res)}
        });
        wx.onMenuShareAppMessage({
         title: '你自己定的标题', // 分享标题
         desc: '你自己定的描述', // 分享描述
         link: url, // 分享链接,该链接域名或路径必须与当前页面对应的公众号JS安全域名一致
         imgUrl: '你自己分享图标的url地址', // 分享图标
         type: 'link', // 分享类型,music、video或link,不填默认为link
         dataUrl: '', // 如果type是music或video,则要提供数据链接,默认为空
        success: function () {
    
  }
});

       
    });

    wx.error(function (res) {
         console.log(res.errMsg);
    });

    

        function test(){
            console.log('ok啦');
            wx.scanQRCode({
                needResult: 1, // 默认为0,扫描结果由微信处理,1则直接返回扫描结果,
                scanType: ["qrCode","barCode"], // 可以指定扫二维码还是一维码,默认二者都有
                success: function (res) {
                    var result = res.resultStr; // 当needResult 为 1 时,扫码返回的结果
                    console.log(result);
                }
            });
        }
  </script>
</body>
</html>
发布了1 篇原创文章 · 获赞 2 · 访问量 65

猜你喜欢

转载自blog.csdn.net/weixin_43834512/article/details/104795840