基于php的微信公眾平臺(tái)開發(fā)入門實(shí)例
本文實(shí)例講述了基于php的微信公眾平臺(tái)開發(fā)方法。分享給大家供大家參考。具體如下:
最近在做微信公眾平臺(tái)開發(fā),一口氣寫了二十幾個(gè)功能,挺有意思的~
今天來分享一下開發(fā)經(jīng)驗(yàn)~
微信公眾平臺(tái)提供的接口很簡單,先看看消息交互流程:
說的通俗一些,用戶使用微信發(fā)送消息 -> 微信將數(shù)據(jù)發(fā)送給開發(fā)者 -> 開發(fā)者處理消息并返回?cái)?shù)據(jù)至微信 -> 微信把返回?cái)?shù)據(jù)發(fā)送給用戶,期間數(shù)據(jù)交互通過XML完成,就這么簡單。
下面寫個(gè)實(shí)例,開發(fā)微信智能聊天機(jī)器人:
1. 注冊微信公眾平臺(tái)賬號(hào)
微信公眾平臺(tái):
https://mp.weixin.qq.com/
注: 目前一張身份證只能注冊兩個(gè)賬號(hào),賬號(hào)名稱關(guān)乎加V認(rèn)證,請慎重注冊。
2. 申請服務(wù)器/虛擬主機(jī)
沒有服務(wù)器/虛擬主機(jī)的童鞋可以使用BAE和SAE,不多介紹。
3. 開啟開發(fā)者模式
微信公眾平臺(tái)有兩個(gè)模式,一個(gè)是編輯模式(傻瓜模式),簡單但功能單一。另一個(gè)是開發(fā)者模式,可以通過開發(fā)實(shí)現(xiàn)復(fù)雜功能。兩個(gè)模式互斥,顯而易見,登錄微信公眾平臺(tái)并通過“高級(jí)功能”菜單開啟開發(fā)者模式。
4. 填寫接口配置信息
同樣是在“高級(jí)功能”菜單中配置,需要配置兩項(xiàng)參數(shù):
URL: 開發(fā)者應(yīng)用訪問地址,目前僅支持80端口,以“http://www.YoonPer.com/weixin/index.php”為例。
TOKEN: 隨意填寫,用于生成簽名,以“YoonPer”為例。
填寫完把下面代碼保存為index.php并上傳至http://www.YoonPer.com/weixin/目錄,最后點(diǎn)擊“提交”完成驗(yàn)證。
<?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; } } } ?>
這玩意兒就是微信公眾平臺(tái)校驗(yàn)URL是否正確接入,研究代碼沒有實(shí)質(zhì)性意義,驗(yàn)證完即可刪除文件,就不詳細(xì)說明了,有興趣的童鞋可以查看官方文檔。
微信公眾平臺(tái)API文檔:
http://mp.weixin.qq.com/wiki/index.php
5. 開發(fā)微信公眾平臺(tái)功能
OK,上面提到了,微信公眾平臺(tái)與開發(fā)者之間的數(shù)據(jù)交互是通過XML完成的,既然用到XML,當(dāng)然得遵循規(guī)范,所以在著手開發(fā)之前先看看官方接口文檔提供的XML規(guī)范,以文本消息為例:
當(dāng)用戶向微信公眾賬號(hào)發(fā)送消息時(shí),微信服務(wù)器會(huì)POST給開發(fā)者一些數(shù)據(jù):
<xml> <!--開發(fā)者微信號(hào)--> <ToUserName><![CDATA[toUser]]></ToUserName> <!--發(fā)送方帳號(hào)(OpenID)--> <FromUserName><![CDATA[fromUser]]></FromUserName> <!--消息創(chuàng)建時(shí)間 (整型)--> <CreateTime>12345678</CreateTime> <!--消息類別 (text文本消息)--> <MsgType><![CDATA1]></MsgType> <!--消息內(nèi)容--> <Content><![CDATA[content]]></Content> <!--消息ID (64位整型)--> <MsgId>1234567890123456</MsgId> </xml>
開發(fā)者在處理完消息后需要返回?cái)?shù)據(jù)給微信服務(wù)器:
<xml> <!--接收方帳號(hào)(OpenID)--> <ToUserName><![CDATA[toUser]]></ToUserName> <!--開發(fā)者微信號(hào)--> <FromUserName><![CDATA[fromUser]]></FromUserName> <!--消息創(chuàng)建時(shí)間 (整型)--> <CreateTime>12345678</CreateTime> <!--消息類別 (text文本消息)--> <MsgType><![CDATA1]></MsgType> <!--回復(fù)消息內(nèi)容--> <Content><![CDATA[content]]></Content> <!--星標(biāo)操作(位0x0001被標(biāo)志時(shí) 星標(biāo)剛收到的消息)--> <FuncFlag>0</FuncFlag> </xml>
除文本消息外,微信公眾平臺(tái)還支持用戶發(fā)送圖片消息、地理位置消息、鏈接消息、事件推送,而開發(fā)者還可以向微信公眾平臺(tái)回復(fù)音樂消息和圖文消息,各類消息XML規(guī)范也可以參見官方文檔。
來看看官方提供的一個(gè)PHP示例,我做了一些精簡:
<?php /*------------------------------------------------- | index.php [ 微信公眾平臺(tái)接口 ] +-------------------------------------------------- | 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ā)送方帳號(hào)(OpenID) $toUsername = $postObj->ToUserName; //獲取接收方賬號(hào) $keyword = trim($postObj->Content); //獲取消息內(nèi)容 $time = time(); //獲取當(dāng)前時(shí)間戳 //---------- 返 回 數(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)在用戶通過微信公眾平臺(tái)發(fā)送任何消息公眾賬號(hào)均會(huì)返回一條內(nèi)容為“http://www.YoonPer.com”的消息。
接下來需要做的就是根據(jù)用戶消息動(dòng)態(tài)返回結(jié)果~
SimSimi(小黃雞)是目前比較火的聊天機(jī)器人,我用CURL開發(fā)了一個(gè)免費(fèi)的SimSimi(小黃雞)接口,傳入關(guān)鍵詞會(huì)返回文本回復(fù),這部分不是本文重點(diǎn),就不多說明,直接上代碼(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 '我還不會(huì)回答這個(gè)問題...'; } } ?>
把上面兩段代碼整合在一起就大功告成了,需要說明一點(diǎn),微信服務(wù)器在5秒內(nèi)收不到響應(yīng)會(huì)斷掉連接,通過此接口有可能會(huì)超時(shí),且SimSimi已經(jīng)屏蔽了BAE和SAE上的抓取請求,推薦使用SimSimi官方收費(fèi)API,速度比較快~
希望本文所述對大家基于php的微信公眾平臺(tái)開發(fā)有所幫助。
- php版微信公眾平臺(tái)之微信網(wǎng)頁登陸授權(quán)示例
- PHP實(shí)現(xiàn)微信網(wǎng)頁授權(quán)開發(fā)教程
- 微信網(wǎng)頁授權(quán)(OAuth2.0) PHP 源碼簡單實(shí)現(xiàn)
- weiphp微信公眾平臺(tái)授權(quán)設(shè)置
- PHP實(shí)現(xiàn)微信小程序用戶授權(quán)的工具類示例
- php判斷頁面是否是微信打開的示例(微信打開網(wǎng)頁)
- PHP對接微信公眾平臺(tái)消息接口開發(fā)流程教程
- php實(shí)現(xiàn)微信公眾平臺(tái)賬號(hào)自定義菜單類
- PHP版微信第三方實(shí)現(xiàn)一鍵登錄及獲取用戶信息的方法
- PHP微信網(wǎng)頁授權(quán)的配置文件操作分析
相關(guān)文章
用Laravel Sms實(shí)現(xiàn)laravel短信驗(yàn)證碼的發(fā)送的實(shí)現(xiàn)
這篇文章主要介紹了用Laravel Sms實(shí)現(xiàn)laravel短信驗(yàn)證碼的發(fā)送的實(shí)現(xiàn),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-11-11php設(shè)計(jì)模式之觀察者模式的應(yīng)用詳解
本篇文章是對php中的觀察者模式進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-05-05PHP實(shí)現(xiàn)新型冠狀病毒疫情實(shí)時(shí)圖的實(shí)例
在本篇文章小編給大家分享一篇關(guān)于PHP新型冠狀病毒肺炎疫情實(shí)時(shí)圖源碼內(nèi)容,有興趣的朋友們可以本地測試下。2020-02-02Redis在Laravel項(xiàng)目中的應(yīng)用實(shí)例詳解
這篇文章主要給大家介紹了關(guān)于Redis在Laravel項(xiàng)目中應(yīng)用的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用laravel具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面跟著小編來一起學(xué)習(xí)學(xué)習(xí)吧。2017-08-08基于php解決json_encode中文UNICODE轉(zhuǎn)碼問題
這篇文章主要介紹了基于php解決json_encode中文UNICODE轉(zhuǎn)碼問題,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-11-11