php微信jssdk配置config參數(shù) 舉例分享朋友圈

微信jssdk的官方文檔 https://mp.weixin.qq.com/wiki?t=resource/res_main&id=mp1421141115

JSSDK使用步驟

步驟一:綁定域名

先登錄微信公眾平臺(tái)進(jìn)入“公眾號(hào)設(shè)置”的“功能設(shè)置”里填寫“JS接口安全域名”慎玖。

備注:登錄后可在“開發(fā)者中心”查看對(duì)應(yīng)的接口權(quán)限碉哑。

步驟二:引入JS文件

在需要調(diào)用JS接口的頁面引入如下JS文件,(支持https):http://res.wx.qq.com/open/js/jweixin-1.4.0.js

如需進(jìn)一步提升服務(wù)穩(wěn)定性碍沐,當(dāng)上述資源不可訪問時(shí)身隐,可改訪問:http://res2.wx.qq.com/open/js/jweixin-1.4.0.js (支持https)。

備注:支持使用 AMD/CMD 標(biāo)準(zhǔn)模塊加載方法加載

步驟三:通過config接口注入權(quán)限驗(yàn)證配置

所有需要使用JS-SDK的頁面必須先注入配置信息,否則將無法調(diào)用(同一個(gè)url僅需調(diào)用一次,對(duì)于變化url的SPA的web app可在每次url變化時(shí)進(jìn)行調(diào)用,目前Android微信客戶端不支持pushState的H5新特性吮便,所以使用pushState來實(shí)現(xiàn)web app的頁面會(huì)導(dǎo)致簽名失敗,此問題會(huì)在Android6.2中修復(fù))幢踏。

wx.config({
    debug: true, // 開啟調(diào)試模式,調(diào)用的所有api的返回值會(huì)在客戶端alert出來髓需,若要查看傳入的參數(shù),可以在pc端打開惑折,參數(shù)信息會(huì)通過log打出授账,僅在pc端時(shí)才會(huì)打印枯跑。
    appId: '', // 必填惨驶,公眾號(hào)的唯一標(biāo)識(shí)
    timestamp: , // 必填,生成簽名的時(shí)間戳
    nonceStr: '', // 必填敛助,生成簽名的隨機(jī)串
    signature: '',// 必填粗卜,簽名
    jsApiList: [] // 必填,需要使用的JS接口列表
});

php代碼:

public function actionSqrcode()
    {
        //時(shí)間戳
        $wx['timestamp'] = time();
        //生成簽名的隨機(jī)串
        $wx['noncestr'] = md5(time());
        //jsapi_ticket是公眾號(hào)用于調(diào)用微信JS接口的臨時(shí)票據(jù)纳击。正常情況下续扔,jsapi_ticket的有效期為7200秒攻臀,通過access_token來獲取。
        $wx['jsapi_ticket'] = $this->actionTicket();
        //分享的地址纱昧,注意:這里是指當(dāng)前網(wǎng)頁的URL刨啸,不包含#及其后面部分,曾經(jīng)的我就在這里被坑了识脆,所以小伙伴們要小心了
        $wx['url'] = 'http://'.$_SERVER['HTTP_HOST'].$_SERVER['REQUEST_URI'];
        $string = sprintf("jsapi_ticket=%s&noncestr=%s&timestamp=%s&url=%s", $wx['jsapi_ticket'], $wx['noncestr'], $wx['timestamp'], $wx['url']);
        //生成簽名
        $wx['signature'] = sha1($string);
        return $wx;
    }

 public function actionAccessToken(){
        $file = file_get_contents('./token');
        $info = json_decode($file,1);
        if ($info && $info['time'] > time())
            return $info['access_token'];

        $url = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=你的appid&secret=你的微信秘鑰";
        $info = file_get_contents($url);
        $info = json_decode($info,1);
        if ($info){
            $info['time'] = time()+$info['expires_in'];
            file_put_contents('./token',json_encode($info));
            return $info['access_token'];
        }else{
            return '失敗';
        }
    }

    public function actionTicket()
    {
        $file = file_get_contents('./ticket');
        $info = json_decode($file,1);
        if ($info && $info['time'] > time())
            return $info['ticket'];

        $url = "https://api.weixin.qq.com/cgi-bin/ticket/getticket?access_token=".$this->actionAccessToken()."&type=jsapi";
        $info = file_get_contents($url);
        $info = json_decode($info,1);
        if ($info){
            $info['time'] = time()+$info['expires_in'];
            file_put_contents('./ticket',json_encode($info));
            return $info['ticket'];
        }else{
            return '失敗';
        }
    }

    public function actionCurl($url,$data,$type = 'json'){
        if($type=='json'){//json $_POST=json_decode(file_get_contents('php://input'), TRUE);
            $headers = array("Content-type: application/json;charset=UTF-8","Accept: application/json","Cache-Control: no-cache", "Pragma: no-cache");
            $data=json_encode($data);
        }
        $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);
        //curl_setopt($ch, CURLOPT_HTTPHEADER, $headers );
        $output = curl_exec($curl);
        curl_close($curl);
        return $output;
    }

js代碼:

<script>
$(function(){
      $.ajax({
        type:"get",
        url:"actionSqrcode",
        async:true,
        success:function(res){
        wx.config({
            debug : false,
            appId : 'res.appid',
            timestamp : "res.timestamp",
            nonceStr : "res.noncestr",
            signature : "res.signature",
            jsApiList : [
                'updateTimelineShareData',
            ]
        });
        wx.ready(function () {      //需在用戶可能點(diǎn)擊分享按鈕前就先調(diào)用
            wx.updateTimelineShareData({
                title: 'xx注冊(cè)領(lǐng)好禮', // 分享標(biāo)題
                link: "http://www.xxx.com", // 分享鏈接设联,該鏈接域名或路徑必須與當(dāng)前頁面對(duì)應(yīng)的公眾號(hào)JS安全域名一致
                imgUrl: 'http://www.xxx.com/123.jpg', // 分享圖標(biāo)
                success: function (r) {
                    // 設(shè)置成功
                }
            });
        });
      }
  });
})

      
    </script>
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市灼捂,隨后出現(xiàn)的幾起案子离例,更是在濱河造成了極大的恐慌,老刑警劉巖悉稠,帶你破解...
    沈念sama閱讀 221,888評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件宫蛆,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡的猛,警方通過查閱死者的電腦和手機(jī)耀盗,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,677評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來衰絮,“玉大人袍冷,你說我怎么就攤上這事∶担” “怎么了胡诗?”我有些...
    開封第一講書人閱讀 168,386評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)淌友。 經(jīng)常有香客問我煌恢,道長(zhǎng),這世上最難降的妖魔是什么震庭? 我笑而不...
    開封第一講書人閱讀 59,726評(píng)論 1 297
  • 正文 為了忘掉前任瑰抵,我火速辦了婚禮,結(jié)果婚禮上器联,老公的妹妹穿的比我還像新娘二汛。我一直安慰自己,他們只是感情好拨拓,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,729評(píng)論 6 397
  • 文/花漫 我一把揭開白布肴颊。 她就那樣靜靜地躺著,像睡著了一般渣磷。 火紅的嫁衣襯著肌膚如雪婿着。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,337評(píng)論 1 310
  • 那天,我揣著相機(jī)與錄音竟宋,去河邊找鬼提完。 笑死,一個(gè)胖子當(dāng)著我的面吹牛丘侠,可吹牛的內(nèi)容都是我干的徒欣。 我是一名探鬼主播,決...
    沈念sama閱讀 40,902評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼蜗字,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼帚称!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起秽澳,我...
    開封第一講書人閱讀 39,807評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤闯睹,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后担神,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,349評(píng)論 1 318
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡孩锡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,439評(píng)論 3 340
  • 正文 我和宋清朗相戀三年亥贸,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了躬窜。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,567評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡炕置,死狀恐怖荣挨,靈堂內(nèi)的尸體忽然破棺而出朴摊,到底是詐尸還是另有隱情,我是刑警寧澤甚纲,帶...
    沈念sama閱讀 36,242評(píng)論 5 350
  • 正文 年R本政府宣布口锭,位于F島的核電站,受9級(jí)特大地震影響介杆,放射性物質(zhì)發(fā)生泄漏鹃操。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,933評(píng)論 3 334
  • 文/蒙蒙 一荆隘、第九天 我趴在偏房一處隱蔽的房頂上張望悲靴。 院中可真熱鬧臭胜,春花似錦癞尚、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,420評(píng)論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽胳徽。三九已至,卻和暖如春养盗,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背箫爷。 一陣腳步聲響...
    開封第一講書人閱讀 33,531評(píng)論 1 272
  • 我被黑心中介騙來泰國打工聂儒, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留虎锚,地道東北人衩婚。 一個(gè)月前我還...
    沈念sama閱讀 48,995評(píng)論 3 377
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像柱徙,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子坐搔,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,585評(píng)論 2 359

推薦閱讀更多精彩內(nèi)容