您好,登錄后才能下訂單哦!
這篇文章主要介紹了基于php微信公眾平臺開發(fā)的示例分析,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
具體如下:
最近在做微信公眾平臺開發(fā),一口氣寫了二十幾個功能,挺有意思的~
今天來分享一下開發(fā)經(jīng)驗~
微信公眾平臺提供的接口很簡單,先看看消息交互流程:
說的通俗一些,用戶使用微信發(fā)送消息 -> 微信將數(shù)據(jù)發(fā)送給開發(fā)者 -> 開發(fā)者處理消息并返回數(shù)據(jù)至微信 -> 微信把返回數(shù)據(jù)發(fā)送給用戶,期間數(shù)據(jù)交互通過XML完成,就這么簡單。
下面寫個實例,開發(fā)微信智能聊天機器人:
1. 注冊微信公眾平臺賬號
微信公眾平臺:
https://mp.weixin.qq.com/
注: 目前一張身份證只能注冊兩個賬號,賬號名稱關(guān)乎加V認證,請慎重注冊。
2. 申請服務(wù)器/虛擬主機
沒有服務(wù)器/虛擬主機的童鞋可以使用BAE和SAE,不多介紹。
3. 開啟開發(fā)者模式
微信公眾平臺有兩個模式,一個是編輯模式(傻瓜模式),簡單但功能單一。另一個是開發(fā)者模式,可以通過開發(fā)實現(xiàn)復(fù)雜功能。兩個模式互斥,顯而易見,登錄微信公眾平臺并通過“高級功能”菜單開啟開發(fā)者模式。
4. 填寫接口配置信息
同樣是在“高級功能”菜單中配置,需要配置兩項參數(shù):
URL: 開發(fā)者應(yīng)用訪問地址,目前僅支持80端口,以“http://www.YoonPer.com/weixin/index.php”為例。
TOKEN: 隨意填寫,用于生成簽名,以“YoonPer”為例。
填寫完把下面代碼保存為index.php并上傳至http://www.YoonPer.com/weixin/目錄,最后點擊“提交”完成驗證。
<?php define("TOKEN", "YoonPer"); //TOKEN值 $wechatObj = new wechat(); $wechatObj->valid(); class wechat { public function valid() { $echoStr = $_GET["echostr"]; if($this->checkSignature()){ echo $echoStr; exit; } } private function checkSignature() { $signature = $_GET["signature"]; $timestamp = $_GET["timestamp"]; $nonce = $_GET["nonce"]; $token = TOKEN; $tmpArr = array($token, $timestamp, $nonce); sort($tmpArr); $tmpStr = implode( $tmpArr ); $tmpStr = sha1( $tmpStr ); if( $tmpStr == $signature ) { return true; } else { return false; } } } ?>
這玩意兒就是微信公眾平臺校驗URL是否正確接入,研究代碼沒有實質(zhì)性意義,驗證完即可刪除文件,就不詳細說明了,有興趣的童鞋可以查看官方文檔。
微信公眾平臺API文檔:
http://mp.weixin.qq.com/wiki/index.php
5. 開發(fā)微信公眾平臺功能
OK,上面提到了,微信公眾平臺與開發(fā)者之間的數(shù)據(jù)交互是通過XML完成的,既然用到XML,當然得遵循規(guī)范,所以在著手開發(fā)之前先看看官方接口文檔提供的XML規(guī)范,以文本消息為例:
當用戶向微信公眾賬號發(fā)送消息時,微信服務(wù)器會POST給開發(fā)者一些數(shù)據(jù):
<xml> <!--開發(fā)者微信號--> <ToUserName><![CDATA[toUser]]></ToUserName> <!--發(fā)送方帳號(OpenID)--> <FromUserName><![CDATA[fromUser]]></FromUserName> <!--消息創(chuàng)建時間 (整型)--> <CreateTime>12345678</CreateTime> <!--消息類別 (text文本消息)--> <MsgType><![CDATA1]></MsgType> <!--消息內(nèi)容--> <Content><![CDATA[content]]></Content> <!--消息ID (64位整型)--> <MsgId>1234567890123456</MsgId> </xml>
開發(fā)者在處理完消息后需要返回數(shù)據(jù)給微信服務(wù)器:
<xml> <!--接收方帳號(OpenID)--> <ToUserName><![CDATA[toUser]]></ToUserName> <!--開發(fā)者微信號--> <FromUserName><![CDATA[fromUser]]></FromUserName> <!--消息創(chuàng)建時間 (整型)--> <CreateTime>12345678</CreateTime> <!--消息類別 (text文本消息)--> <MsgType><![CDATA1]></MsgType> <!--回復(fù)消息內(nèi)容--> <Content><![CDATA[content]]></Content> <!--星標操作(位0x0001被標志時 星標剛收到的消息)--> <FuncFlag>0</FuncFlag> </xml>
除文本消息外,微信公眾平臺還支持用戶發(fā)送圖片消息、地理位置消息、鏈接消息、事件推送,而開發(fā)者還可以向微信公眾平臺回復(fù)音樂消息和圖文消息,各類消息XML規(guī)范也可以參見官方文檔。
來看看官方提供的一個PHP示例,我做了一些精簡:
<?php /*------------------------------------------------- | index.php [ 微信公眾平臺接口 ] +-------------------------------------------------- | Author: LimYoonPer +------------------------------------------------*/ $wechatObj = new wechat(); $wechatObj->responseMsg(); class wechat { public function responseMsg() { //---------- 接 收 數(shù) 據(jù) ---------- // $postStr = $GLOBALS["HTTP_RAW_POST_DATA"]; //獲取POST數(shù)據(jù) //用SimpleXML解析POST過來的XML數(shù)據(jù) $postObj = simplexml_load_string($postStr,'SimpleXMLElement',LIBXML_NOCDATA); $fromUsername = $postObj->FromUserName; //獲取發(fā)送方帳號(OpenID) $toUsername = $postObj->ToUserName; //獲取接收方賬號 $keyword = trim($postObj->Content); //獲取消息內(nèi)容 $time = time(); //獲取當前時間戳 //---------- 返 回 數(shù) 據(jù) ---------- // //返回消息模板 $textTpl = "<xml> <ToUserName><![CDATA[%s]]></ToUserName> <FromUserName><![CDATA[%s]]></FromUserName> <CreateTime>%s</CreateTime> <MsgType><![CDATA[%s]]></MsgType> <Content><![CDATA[%s]]></Content> <FuncFlag>0</FuncFlag> </xml>"; $msgType = "text"; //消息類型 include('simsimi.php'); $contentStr = simsimi($keyword); //返回消息內(nèi)容 //格式化消息模板 $resultStr = sprintf($textTpl,$fromUsername,$toUsername,$time,$msgType,$contentStr); echo $resultStr; //輸出結(jié)果 } } ?>
把代碼保存為index.php并上傳至http://www.YoonPer.com/weixin/目錄,如果剛才沒刪除該文件,則直接覆蓋。
現(xiàn)在用戶通過微信公眾平臺發(fā)送任何消息公眾賬號均會返回一條內(nèi)容為“http://www.YoonPer.com”的消息。
接下來需要做的就是根據(jù)用戶消息動態(tài)返回結(jié)果~
SimSimi(小黃雞)是目前比較火的聊天機器人,我用CURL開發(fā)了一個免費的SimSimi(小黃雞)接口,傳入關(guān)鍵詞會返回文本回復(fù),這部分不是本文重點,就不多說明,直接上代碼(2014.07.28更新):
<?php /*------------------------------------------------- | simsimi.php [ 智能聊天(simsimi) ] +-------------------------------------------------- | Author: LimYoonPer +------------------------------------------------*/ function simsimi ($keyword) { $keyword = urlencode($keyword); //----------- 獲取COOKIE ----------// $url = "http://www.simsimi.com/"; $ch = curl_init($url); curl_setopt($ch, CURLOPT_HEADER, 1); curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); $content = curl_exec($ch); list($header, $body) = explode("\r\n\r\n", $content); preg_match_all("/set\-cookie:([^\r\n]*);/iU", $header, $matches); $cookie = implode(';', $matches[1]).";simsimi_uid=1;"; curl_close($ch); //----------- 抓 取 回 復(fù) ----------// $url = "http://www.simsimi.com/func/reqN?lc=ch&ft=0.0&req=$keyword&fl=http%3A%2F%2Fwww.simsimi.com%2Ftalk.htm"; $ch = curl_init($url); curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); curl_setopt($ch, CURLOPT_COOKIE, $cookie); $content = json_decode(curl_exec($ch), 1); curl_close($ch); if ( $content['result'] == '200' ) { return $content['sentence_resp']; } else { return '我還不會回答這個問題...'; } } ?>
把上面兩段代碼整合在一起就大功告成了,需要說明一點,微信服務(wù)器在5秒內(nèi)收不到響應(yīng)會斷掉連接,通過此接口有可能會超時,且SimSimi已經(jīng)屏蔽了BAE和SAE上的抓取請求,推薦使用SimSimi官方收費API,速度比較快~
感謝你能夠認真閱讀完這篇文章,希望小編分享的“基于php微信公眾平臺開發(fā)的示例分析”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關(guān)注億速云行業(yè)資訊頻道,更多相關(guān)知識等著你來學(xué)習!
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。