您好,登錄后才能下訂單哦!
這篇文章主要介紹微信公眾平臺開發(fā)之a(chǎn)ccess_token、日志的示例分析,文中介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們一定要看完!
1)兩種access_token,網(wǎng)頁授權(quán)access_token和普通access_token
1、微信網(wǎng)頁授權(quán)是通過OAuth3.0機(jī)制實(shí)現(xiàn)的,在用戶授權(quán)給公眾號后,公眾號可以獲取到一個網(wǎng)頁授權(quán)特有的接口調(diào)用憑證(網(wǎng)頁授權(quán)access_token),通過網(wǎng)頁授權(quán)access_token可以進(jìn)行授權(quán)后接口調(diào)用,如獲取用戶基本信息。
2、其他微信接口,需要通過基礎(chǔ)支持中的“獲取access_token”接口來獲取到的普通access_token調(diào)用。access_token是公眾號的全局唯一票據(jù),access_token的有效期目前為2個小時,需定時刷新,重復(fù)獲取將導(dǎo)致上次獲取的access_token失效。
2)分別獲取access_token
1、網(wǎng)頁授權(quán)的:點(diǎn)擊查看網(wǎng)頁授權(quán)獲取用戶基本信息文檔,通過查看這個文檔,
可以看到通過code換取網(wǎng)頁授權(quán)access_token,而這個code是通過微信的一個授權(quán)鏈接獲取到的,然后再根據(jù)文檔中的請求獲取到的,具體的鏈接地址和參數(shù)可以參考文檔。
/** * 創(chuàng)建一個需要通過微信的OAuth3.0認(rèn)證的服務(wù)url * @param $url 服務(wù)號需要認(rèn)證訪問的url * @param $scope string snsapi_userinfo | snsapi_base * snsapi_userinfo 可以用來獲取用戶信息 * snsapi_base 可以用來獲取openid * @param string $state 自定義狀態(tài)值 * 此處約定為from_weixin代表是從微信認(rèn)證過來,一般無需輕易變化 * @return string 返回認(rèn)證url地址 */ public function createAuthUrl($url, $scope = 'snsapi_base', $state = 'from_weixin') { $url = strval($url); $authUrl = 'https://open.weixin.qq.com/connect/oauth3/authorize'; /** * 此處有大坑,請不要打亂param的順序 * 否則微信認(rèn)證界面會出現(xiàn)白屏 */ $param = array( 'appid' => $this->appId, 'redirect_uri' => urlencode($url), 'response_type' => 'code', 'scope' => $scope, 'state' => $state ); $seg = array(); foreach ($param as $k => $v) { $seg[] = "{$k}={$v}"; } return $authUrl . '?' . join('&', $seg) . '#wechat_redirect'; }
2、普通的:點(diǎn)擊查看獲取access token文檔,通過三個參數(shù)獲取到。
這里需要注意的是,獲取到的token,是有時效性的,2 個小時,所以我會保存在MongoDB中,先從數(shù)據(jù)庫中比對超時了沒有,沒有的話就直接從數(shù)據(jù)庫中獲取,減少不必要的請求。
在與微信的交互中,會產(chǎn)生很多日志信息,并且開發(fā)的時候經(jīng)常需要分析這些日志,這里我將日志都保存在了MongoDB中。MongoDB方便的地方是任何結(jié)構(gòu)的數(shù)據(jù)都能放在一個document中,不像MySQL要定義好字段名,我經(jīng)常調(diào)試的時候?qū)⒏鞣N結(jié)構(gòu)放在一個document中。
在微信的入口頁面中,也就是前面提到的URL(服務(wù)器地址),會在這里面做保存日志的邏輯。邏輯包括關(guān)注的時候推送一條消息,二維碼掃描關(guān)注,點(diǎn)擊某個菜單產(chǎn)生事件,點(diǎn)擊菜單的超鏈接等。
日志結(jié)構(gòu)如下:
1、代碼中包括簽名驗(yàn)證邏輯
2、通過file_get_contents('php://input')來獲取請求數(shù)據(jù),就是下面的getRawMsg方法
3、將推送日志直接塞入到MongoDB中
4、將接收到的請求信息SimpleXMLElement對象,就是下面的parseMsg方法
5、handleEventMsg就是在處理各種不同情況了
/** * 微信公眾號入口 */ public function actionPortal() { $weixin = new Weixin(); //簽名驗(yàn)證邏輯 // if($weixin->checkSignature()){ // echo $_GET['echostr']; // } // exit; //讀取原始請求數(shù)據(jù) $msg = $weixin->getRawMsg(); //推送日志 $pushlog = new WeixinPushLog(); $pushlog->logWeixinPush($msg); $msgObj = $weixin->parseMsg($msg); if ($msgObj === false || !is_object($msgObj)) { exit; } switch ($msgObj->MsgType) { case 'event' : //接收事件消息 $this->handleEventMsg($msgObj); break; default : //todo break; } }
public function getRawMsg() { return file_get_contents('php://input'); } /** * 解析接收到的消息 * @param string $msg 消息體 * @return bool|SimpleXMLElement */ public function parseMsg($msg = '') { if (!$msg || empty($msg)) { return false; } $msgObj = simplexml_load_string($msg, 'SimpleXMLElement', LIBXML_NOCDATA); if ($msgObj === false || !($msgObj instanceof \SimpleXMLElement)) { return false; } return $msgObj; }
6、如果要推送消息,die這個方法得要加上
7、下面的代碼只列舉了兩種事件情況,一種是訂閱、一種是點(diǎn)擊事件
8、createRawTuWenMsg是在拼接XML,點(diǎn)擊查看模板消息接口。
private function handleEventMsg($msgObj) { $weixin = new Weixin(); $openId = $msgObj->FromUserName; $fromUserName = $msgObj->ToUserName; //未關(guān)注,關(guān)注后推送 if ($msgObj->Event == 'subscribe') { $pushData['PicUrl'] = 'http://mmbiz.qpic.cn/'; $pushData['Title'] = '基因檢測,帶你一起探索生命的奧妙 '; $pushData['Description'] = '為什么不同人在身高、體重、膚色和形狀上長得不一樣?但是往往又和自己的父母相似?'; $pushData['Url'] = 'http://mp.weixin.qq.com'; $msg = $weixin->createRawTuWenMsg($fromUserName, $openId, array($pushData)); die($msg); }elseif($msgObj->Event == 'CLICK'){ //die($msg); } }
public function createRawTuWenMsg($fromUserName, $toUserName, $items = array()) { if (!is_array($items)) { return ''; } $count = count($items); $its = ''; foreach ($items as $item) { $its .= <<<ITEMTPL <item> <Title><![CDATA[{$item['Title']}]]></Title> <Description><![CDATA[{$item['Description']}]]></Description> <PicUrl><![CDATA[{$item['PicUrl']}]]></PicUrl> <Url><![CDATA[{$item['Url']}]]></Url> </item> ITEMTPL; } $msg = <<<MSG <xml> <ToUserName><![CDATA[{$toUserName}]]></ToUserName> <FromUserName><![CDATA[{$fromUserName}]]></FromUserName> <CreateTime>12345678</CreateTime> <MsgType><![CDATA[news]]></MsgType> <ArticleCount>{$count}</ArticleCount> <Articles> {$its} </Articles> </xml> MSG; return $msg; }
以上是“微信公眾平臺開發(fā)之a(chǎn)ccess_token、日志的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關(guān)知識,歡迎關(guān)注億速云行業(yè)資訊頻道!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。