首頁 >後端開發 >php教程 >php微信瀏覽器分享設定以及回呼詳解_php實例

php微信瀏覽器分享設定以及回呼詳解_php實例

WBOY
WBOY原創
2016-08-17 13:02:35898瀏覽

在微信中分享給好友/分享到朋友圈這個功能應該是比較常用的了,就拿分享到朋友圈舉例,分享出去的內容在朋友圈的展示是以一張小圖片+一個簡單的介紹的形式來給好友看到的,點擊後才是詳情,那麼這麼一來,這張小圖片和這段小簡介就直接成為了這個被分享後的內容的被點擊率的重中之重。在預設情況下,這張圖片會載入內容主題部分的第一張大圖片,而簡介只會載入一個網址。這樣的展示方式還是相當不盡人意的,那我們來看一下這一些內容,是透過什麼形式來設定的,拿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: '<&#63;php echo APPID;&#63;>', // 必填,公众号的唯一标识
  timestamp: <&#63;php echo $timestamp;&#63;>, // 必填,生成签名的时间戳
  nonceStr: '<&#63;php echo $noncestr;&#63;>', // 必填,生成签名的随机串
  signature: '<&#63;php echo $signature;&#63;>',// 必填,签名
  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'].'&#63;'.$_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回調以及取消分享後的回調,用來做一些判斷用戶分享朋友圈後顯示心理測試答案之類的小功能還是很有用的。

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

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn