php實現微信分享朋友鏈接功能

這篇文章主要爲大家詳細介紹了php實現微信分享朋友鏈接,具有一定的參考價值,感興趣的小夥伴們可以參考一下

本文爲大家分享了php實現微信分享朋友鏈接,供大家參考,具體內容如下

不是些高深知識,但是第一次做,確實費了很多的時間,終於一點一點的扣了出來,目前已經使用中。

解決這個問題,總共碰到了幾次BUG,1是生成的簽名不對,自己打印出來,在去微信的簽名算法頁面一一覈對.這時候如果對了,還是不成功.那就是需要動態獲取URL鏈接的。最後需要將 函數寫在爲微信的ready函數內,但是看文檔講需要用戶觸發的函數可以不寫進去,所以當所有的問題解決後,發送給朋友的鏈接總是原生態的,後臺又嘗試將函數寫入ready才解決了此事。

PHP

 $this->time1 = time(); 
 $this->appId = 'xxxxxxx'; //自己平臺的appid
 $this->nonceStr = 'xxxxxxxx';// 祕鑰
 $res = file_get_contents("https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=xxxx&secret=xxxxx");// 獲得token
 $ress = json_decode($res,True);
 $token = $ress['access_token'];// 取出 至於存儲代碼就不列舉了 
 $js = file_get_contents("https://api.weixin.qq.com/cgi-bin/ticket/getticket?access_token=".$token."&type=jsapi");
 $jss = json_decode($js,True);
 $jsapi_ticket = $jss['ticket'];// 取出JS憑證, 至於存儲代碼就不列舉了

  //開始簽名算法了 
 $dataa['noncestr'] = 'sjijfdif'; //隨意字符串 一會要傳到JS裏去.要求一致 
 $dataa['jsapi_ticket'] = $jsapi_ticket;
 $dataa['timestamp'] = $this->time1;
 $this->url1 = $dataa['url'] = 'http://'.$_SERVER['HTTP_HOST'].$_SERVER['REQUEST_URI'];//動態獲取URL
 ksort($dataa);
 $signature = '';
 foreach($dataa as $k => $v){
 $signature .= $k.'='.$v.'&';
 }
 $signature = substr($signature, 0, strlen($signature)-1); 
 $this->signature = sha1($signature);// 必填,簽名,見附錄1

HTML

<script>
 wx.config({
 debug: false, // 開啓調試模式,調用的所有api的返回值會在客戶端alert出來,若要查看傳入的參數,可以在pc端打開,參數信息會通過log打出,僅在pc端時纔會打印。
 appId: "<{$appId}>", // 必填,公衆號的唯一標識
 timestamp:"<{$time1}>" , // 必填,生成簽名的時間戳
 nonceStr: "<{$nonceStr}>", // 必填,生成簽名的隨機串
 signature: "<{$signature}>",// 必填,簽名,見附錄1
 jsApiList: ['onMenuShareAppMessage'] // 必填,需要使用的JS接口列表,所有JS接口列表見附錄2
 }); 
 wx.ready(function(){
 wx.onMenuShareAppMessage({
 title: '周亮', // 分享標題
 desc: '嘻嘻哈哈程序猿', // 分享描述
 link: "<{$url1}>", // 分享鏈接
 imgUrl: '/Uploads/20160921/57e24dc555372.jpg', // 分享圖標
 type: 'link', // 分享類型,music、video或link,不填默認爲link
 dataUrl: '', // 如果type是music或video,則要提供數據鏈接,默認爲空
 success: function () { 
 alert('分享成功');
 },
 cancel: function () { 
 alert('取消分享了');
 }
 });
 });
 </script>

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持神馬文庫。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章