在微信中分享給好友/分享到朋友圈這個功能應該是比較常用的了,就拿分享到朋友圈舉例,分享出去的內容在朋友圈的展示是以一張小圖片+一個簡單的介紹的形式來給好友看到的,點擊後才是詳情,那麼這麼一來,這張小圖片和這段小簡介就直接成為了這個被分享後的內容的被點擊率的重中之重。在默認情況下,這張圖片會載入內容主題部分的第一張大圖片,而簡介只會加載一個網址。這樣的展示方式還是相當不盡如人意的,那我們來看一下這一些內容,是通過什麼形式來設置的,拿PHP來做一個舉例:
首先我們需要有一個公眾號,並且獲得appid及appsecret。
然後,我們通過appid和appsecret,就可以向微信平台來換取access_token了。
define("APPID", $appid); define("APPSECRET", $appsecret); // 獲取access_token $token_access_url = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=" . APPID . "&secret=" . APPSECRET; $res = file_get_contents($token_access_url); //獲取文件內容或獲取網絡請求的內容 $result = json_decode($res, true); //接受一個 JSON 格式的字符串並且把它轉換為 PHP 變量 $access_token = $result['access_token'];
通過access_token,我們可以向微信平台索取一個jsapi_ticket:
// 獲取jsapi_ticket $ticket_url = "https://api.weixin.qq.com/cgi-bin/ticket/getticket?access_token=TOKEN"; $res = file_get_contents($ticket_url); //獲取文件內容或獲取網絡請求的內容 $result = json_decode($res, true); //接受一個 JSON 格式的字符串並且把它轉換為 PHP 變量 $ticket = $result['ticket'];
好了,准備工作就緒,我們可以開始我們的設置了。
微信的分享設置是通過wx.config來進行的。
<script> wx.config({ debug: false, // 開啟調試模式,調用的所有api的返回值會在客戶端alert出來,若要查看傳入的參數,可以在pc端打開,參數信息會通過log打出,僅在pc端時才會打印。 appId: '<?php echo APPID;?>', // 必填,公眾號的唯一標識 timestamp: <?php echo $timestamp;?>, // 必填,生成簽名的時間戳 nonceStr: '<?php echo $noncestr;?>', // 必填,生成簽名的隨機串 signature: '<?php echo $signature;?>',// 必填,簽名 jsApiList: ['onMenuShareTimeline','onMenuShareAppMessage'] // 必填,需要使用的JS接口列表 }); </script>
中間appid就是我們微信公眾號的appid,timestamp是當前的時間戳,noncestr是隨機的字符串,用來生成簽名的,signature是生成的簽名,jsapilist是我們需要使用的微信接口,這邊的話我們就使用分享給好友以及分享到朋友圈這兩個接口就可以了。
簡單列一下timestamp,noncestr,以及signature的生成流程:
// 生成簽名 // 生成隨機字符串 class RandChar{ function getRandChar($length){ $str = null; $strPol = "ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789abcdefghijklmnopqrstuvwxyz"; $max = strlen($strPol)-1; for($i=0;$i<$length;$i++){ $str.=$strPol[rand(0,$max)];//rand($min,$max)生成介於min和max兩個數之間的一個隨機整數 } return $str; } } $randCharObj = new RandChar(); $noncestr = $randCharObj->getRandChar(16); $timestamp = time(); if ($_SERVER['QUERY_STRING']){ $url = 'http://'.$_SERVER['HTTP_HOST'].$_SERVER['PHP_SELF'].'?'.$_SERVER['QUERY_STRING']; }else{ $url = 'http://'.$_SERVER['HTTP_HOST'].$_SERVER['PHP_SELF']; } $parameters = array("noncestr" => $noncestr, "jsapi_ticket" => $ticket, "timestamp" => $timestamp, "url" => $url); ksort($parameters); $string1 = ""; foreach ($parameters as $key => $val){ $string1 .= $key."=".$val."&"; } $string1 = substr($string1,0,-1); $signature = sha1($string1);
至此,我們對於wx.config的一個配置就已經完成了,接下去就可以自由設置我們剛剛提到的小圖片和簡介內容了:
wx.ready(function(){ // 分享到朋友圈設置 wx.onMenuShareTimeline({ title: '測試標題', // 分享標題 link: 'http://www.baidu.com', // 分享鏈接 imgUrl: 'http://mp.weixin.qq.com/wiki/static/assets/dc5de672083b2ec495408b00b96c9aab.png', // 分享圖標 success: function () { alert("分享成功"); }, cancel: function () { alert("分享失敗"); } }); // 分享給好友 wx.onMenuShareAppMessage({ title: '測試標題', // 分享標題 desc: '測試分享描述', // 分享描述 link: 'http://www.baidu.com', // 分享鏈接 imgUrl: 'http://mp.weixin.qq.com/wiki/static/assets/dc5de672083b2ec495408b00b96c9aab.png', // 分享圖標 type: '', // 分享類型,music、video或link,不填默認為link dataUrl: '', // 如果type是music或video,則要提供數據鏈接,默認為空 success: function () { alert("分享成功"); }, cancel: function () { alert("分享失敗"); } }); })
中間提一下,success和cancel這兩個的值也是相當常用的,分別表示成功分享後的js回調以及取消分享後的回調,用來做一些判斷用戶分享朋友圈後顯示心理測試答案之類的小功能還是很有用的哦。