微信公眾平臺現(xiàn)在有許多的api接口了我們可以利用微信公眾平臺來實現(xiàn)許多的一些功能,下面來看一個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/
注:目前一張身份證只能注冊兩個賬號,賬號名稱關乎加V認證,請慎重注冊.
2.申請服務器/虛擬主機
沒有服務器/虛擬主機的童鞋可以使用BAE和SAE,不多介紹.
3.開啟開發(fā)者模式
微信公眾平臺有兩個模式,一個是編輯模式(傻瓜模式),簡單但功能單一。另一個是開發(fā)者模式,可以通過開發(fā)實現(xiàn)復雜功能。兩個模式互斥,顯而易見,登錄微信公眾平臺并通過“高級功能”菜單開啟開發(fā)者模式。
4.填寫接口配置信息
同樣是在“高級功能”菜單中配置,需要配置兩項參數(shù):
URL: 開發(fā)者應用訪問地址,目前僅支持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; //Vevb.com
- } 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ā)送消息時,微信服務器會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ù)給微信服務器:
- <xml>
- <!--接收方帳號(OpenID)-->
- <ToUserName><![CDATA[toUser]]></ToUserName>
- <!--開發(fā)者微信號-->
- <FromUserName><![CDATA[fromUser]]></FromUserName>
- <!--消息創(chuàng)建時間 (整型)-->
- <CreateTime>12345678</CreateTime>
- <!--消息類別 (text文本消息)-->
- <MsgType><![CDATA1]></MsgType>
- <!--回復消息內(nèi)容-->
- <Content><![CDATA[content]]></Content>
- <!--星標操作(位0x0001被標志時 星標剛收到的消息)-->
- <FuncFlag>0</FuncFlag>
- </xml>
除文本消息外,微信公眾平臺還支持用戶發(fā)送圖片消息、地理位置消息、鏈接消息、事件推送,而開發(fā)者還可以向微信公眾平臺回復音樂消息和圖文消息,各類消息XML規(guī)范也可以參見官方文檔。
來看看官方提供的一個PHP示例,我做了一些精簡:
- <?php
- $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"; //消息類型
- $contentStr = 'http://www.YoonPer.com'; //返回消息內(nèi)容
- //Vevb.com
- //格式化消息模板
- $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(小黃雞)接口,傳入關鍵詞會返回文本回復,這部分不是本文重點,就不多說明,直接上代碼(2014.07.28更新):
- <?php
- 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);
- //----------- 抓 取 回 復 ----------//
- $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 '我還不會回答這個問題...';
- }
- }
- ?>
把上面兩段代碼整合在一起就大功告成了,需要說明一點,微信服務器在5秒內(nèi)收不到響應會斷掉連接,通過此接口有可能會超時,且SimSimi已經(jīng)屏蔽了BAE和SAE上的抓取請求,推薦使用SimSimi官方收費API,速度比較快~
新聞熱點
疑難解答