微信JS SDK接入的幾點注意事項


微信JS SDK接入,主要可以先參考官網說明文檔,總結起來有幾個步驟:

1.綁定域名:
先登錄微信公眾平台進入“公眾號設置”的“功能設置”里填寫“JS接口安全域名”。
備注:登錄后可在“開發者中心”查看對應的接口權限。

2.引入JS文件:在需要調用JS接口的頁面引入如下JS文件,(支持https):http://res.wx.qq.com/open/js/jweixin-1.2.0.js,
備注:支持使用 AMD/CMD 標准模塊加載方法加載,這里補充引入jquery.cookie.js,sha1.js,后面需要用

3.獲取access_token,再獲取jsapi_ticket,由於不能頻繁調用獲取jsapi_ticket的函數,可以保存一份全局的jsapi_ticket,存放在cookie中,如果過時了再重新獲取;另外,這兩個獲取操作建議放到服務端確保安全性;

4.拼接noncestr(隨機字符串), 有效的jsapi_ticket, timestamp(時間戳), url(當前網頁的URL,不包含#及其后面部分),對所有待簽名參數按照字段名的ASCII 碼從小到大排序(字典序)后,使用URL鍵值對的格式(即key1=value1&key2=value2…)拼接成字符串string1。這里需要注意的是所有參數名均為小寫字符。

5.sha1加密生成簽名signature;

6.配置wx.config,wx.ready,wx.error等方法,其中wx.ready是配置成功之后的回調,建議其他方法如微信分享wx.onMenuShareTimeline,wx.onMenuShareAppMessage之類都放到ready里面,以達到同步執行的目的;

服務端接口:

//access_token是公眾號的全局唯一票據
    public function getTokenForJS() {
        $appid = "不告訴你";
        $secret = "不告訴你";
        $url = "https://api.weixin.qq.com/cgi-bin/token?appid=".$appid."&secret=".$secret."&grant_type=client_credential";
        $result = http_request($url);
        echo $result;exit;
    }
    
    //獲取ticket
    public function getTicket(){
        $access_token = I("get.access_token");
        $url = "https://api.weixin.qq.com/cgi-bin/ticket/getticket?access_token=".$access_token."&type=jsapi";
		//$this->ajaxJSON($url);
        $result = http_request($url);
        echo $result;exit;
    }
    
    function http_request($url, $data = null)
	{
		$curl = curl_init();
		curl_setopt($curl, CURLOPT_URL, $url);
		curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, false);
		curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, false);
		if (!empty($data)) {
			curl_setopt($curl, CURLOPT_POST, 1);
			curl_setopt($curl, CURLOPT_POSTFIELDS, $data);
		}
		curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
		$info = curl_exec($curl);
		curl_close($curl);
		return $info;
	}

前端js:

function setWechatJS() {
    // var temp = "jsapi_ticket=kgt8ON7yVITDhtdwci0qeRukvrGB1QLAfzCcybh4a_VMg6rgB4OhdsD4O2ruRI0OUPG5VfpKlYYWXcyEeChbBw&noncestr=4df32E3jY6YneEPNfGfs&timestamp=1498120656&url=http://m.galaxy-immi.com/country/";
    // alert( hex_sha1(temp)); return false;
    //生成隨機字符串
    var randomString = function(len) {
        len = len || 32;
        var $chars = 'ABCDEFGHJKMNPQRSTWXYZabcdefhijkmnprstwxyz2345678';    /****默認去掉了容易混淆的字符oOLl,9gq,Vv,Uu,I1****/
        var maxPos = $chars.length;
        var pwd = '';
        for (var i = 0; i < len; i++) {
            pwd += $chars.charAt(Math.floor(Math.random() * maxPos));
        }
        return pwd;
    };

    var showShareSetting = function () {
        console.log("title="+title+",description="+description+",link="+url+",imgUrl="+imgUrl);
    };

    //wx配置參數
    var jsapi_ticket = $.cookie('jsapi_ticket');
    var hello2 = 'hello222';
    console.log("jsapi_ticket="+jsapi_ticket);

    var wxConfig = function () {
        //alert('ddd='+jsapi_ticket);
        //獲取當前url,不含#以及之后的部分
        var timestamp = new Date().getTime();  //生成簽名的時間戳(當前時間)
        var noncestr = randomString(20);
        var signature = '';       //簽名
        var url = window.location.href;
        var index = url.indexOf('#');
        if(index !== -1 ) {
            url = url.slice(0,index);
        }
        var temp = "jsapi_ticket="+jsapi_ticket+"&noncestr="+noncestr+"&timestamp="+timestamp+"&url="+url;
        signature = hex_sha1(temp);
        console.log("signature="+signature);
        wx.config({
            debug: false, // 開啟調試模式,調用的所有api的返回值會在客戶端alert出來,若要查看傳入的參數,可以在pc端打開,參數信息會通過log打出,僅在pc端時才會打印。
            appId: 'wx0875a197e0e5bcd7', // 必填,公眾號的唯一標識
            timestamp: timestamp, // 必填,生成簽名的時間戳
            nonceStr: noncestr, // 必填,生成簽名的隨機串
            signature: signature,// 必填,簽名,見附錄1
            jsApiList: [
                'checkJsApi',
                'onMenuShareTimeline',
                'onMenuShareAppMessage',
                'onMenuShareQQ',
                'onMenuShareWeibo',
                'onMenuShareQZone'
            ] // 必填,需要使用的JS接口列表,所有JS接口列表見附錄2
        });

        wx.ready(function () {
            //配置成功之后回調
            console.log("微信JS SDK配置成功!");
            //實例化title\imgUrl
            title = $('title').html();   //默認取title
            description = $("meta[name='description']").attr('content');
            //判斷當前頁面類型取縮略圖
            $("body img").each(function(index,element){
                var width = $(element).width();
                var height = $(element).height();
                var Src = $(element).attr("src");
                if(width>200 && height>200){//去頁面中第一張寬高都大於200的圖片
                    imgUrl = Src;
                    //console.log(Src);
                    return false;
                }else{//未在頁面中取到合適的圖片就選取銀河的logo圖
                    imgUrl = MyPic+"/H5/img/icon.png";
                }
            });
            showShareSetting();
            //分享到朋友圈
            wx.onMenuShareTimeline({
                title: title, // 分享標題
                link: url, // 分享鏈接,該鏈接域名或路徑必須與當前頁面對應的公眾號JS安全域名一致
                imgUrl: imgUrl, // 分享圖標
                success: function () {
                    // 用戶確認分享后執行的回調函數
                    showShareSetting();
                },
                cancel: function () {
                    // 用戶取消分享后執行的回調函數
                }
            });
            //分享給朋友
            wx.onMenuShareAppMessage({
                title: title, // 分享標題
                desc: description, // 分享描述
                link: url, // 分享鏈接,該鏈接域名或路徑必須與當前頁面對應的公眾號JS安全域名一致
                imgUrl: imgUrl, // 分享圖標
                type: '', // 分享類型,music、video或link,不填默認為link
                dataUrl: '', // 如果type是music或video,則要提供數據鏈接,默認為空
                success: function () {
                    // 用戶確認分享后執行的回調函數
                    showShareSetting();
                },
                cancel: function () {
                    // 用戶取消分享后執行的回調函數
                }
            });
            //分享到QQ
            wx.onMenuShareQQ({
                title: title, // 分享標題
                desc: description, // 分享描述
                link: url, // 分享鏈接
                imgUrl: imgUrl, // 分享圖標
                success: function () {
                    // 用戶確認分享后執行的回調函數
                    showShareSetting();
                },
                cancel: function () {
                    // 用戶取消分享后執行的回調函數
                }
            });

            //分享到QQ空間
            wx.onMenuShareQZone({
                title: title, // 分享標題
                desc: description, // 分享描述
                link: url, // 分享鏈接
                imgUrl: imgUrl, // 分享圖標
                success: function () {
                    // 用戶確認分享后執行的回調函數
                    showShareSetting();
                },
                cancel: function () {
                    // 用戶取消分享后執行的回調函數
                }
            });
        });
        wx.error(function(res){
            console.log("微信JS SDK配置錯誤!");
            // config信息驗證失敗會執行error函數,如簽名過期導致驗證失敗,具體錯誤信息可以打開config的debug模式查看,也可以在返回的res參數中查看,對於SPA可以在這里更新簽名。
        });
    };

    //待分享生成的標題、鏈接、縮略圖
    var title,url,imgUrl,description;
    //本地cookie查找不到緩存再去請求網絡
    if(typeof (jsapi_ticket) == 'undefined' || jsapi_ticket == ''){
        //alert('aaa='+jsapi_ticket);
        //以下步驟分別獲取全局access_token、jsapi_ticket、signature
        $.get(MyUrl+"getTokenForJS",function (data) {
            var access_token = data['access_token'];
            //獲取全局access_token,以及7200秒之后刷新的問題
            //先出cookie中取,如果沒有,
            $.get(MyUrl+"getTicket?access_token="+access_token,function(data){
                jsapi_ticket = data['ticket'];
                //保存當前jsapi_ticket
                var date = new Date();
                date.setTime(date.getTime()+7200*1000);//只能這么寫,10表示10秒鍾
                //?替換成分鍾數如果為60分鍾則為 60 * 60 *1000
                $.cookie('jsapi_ticket',jsapi_ticket,{expires:date,path:'/'}); //有效期7200秒
                console.log("jsapi_ticket="+jsapi_ticket);
                //alert('ccc='+jsapi_ticket);
                wxConfig();
            },'json');

        },'json');
    }else {
        //alert('bbb='+jsapi_ticket);
        wxConfig();
    }
}


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM