基于php的微信公眾平臺(tái)開(kāi)發(fā)入門實(shí)例
本文實(shí)例講述了基于php的微信公眾平臺(tái)開(kāi)發(fā)方法。分享給大家供大家參考。具體如下:
最近在做微信公眾平臺(tái)開(kāi)發(fā),一口氣寫(xiě)了二十幾個(gè)功能,挺有意思的~

今天來(lái)分享一下開(kāi)發(fā)經(jīng)驗(yàn)~
微信公眾平臺(tái)提供的接口很簡(jiǎn)單,先看看消息交互流程:

說(shuō)的通俗一些,用戶使用微信發(fā)送消息 -> 微信將數(shù)據(jù)發(fā)送給開(kāi)發(fā)者 -> 開(kāi)發(fā)者處理消息并返回?cái)?shù)據(jù)至微信 -> 微信把返回?cái)?shù)據(jù)發(fā)送給用戶,期間數(shù)據(jù)交互通過(guò)XML完成,就這么簡(jiǎn)單。
下面寫(xiě)個(gè)實(shí)例,開(kāi)發(fā)微信智能聊天機(jī)器人:
1. 注冊(cè)微信公眾平臺(tái)賬號(hào)
微信公眾平臺(tái):
https://mp.weixin.qq.com/
注: 目前一張身份證只能注冊(cè)兩個(gè)賬號(hào),賬號(hào)名稱關(guān)乎加V認(rèn)證,請(qǐng)慎重注冊(cè)。
2. 申請(qǐng)服務(wù)器/虛擬主機(jī)
沒(méi)有服務(wù)器/虛擬主機(jī)的童鞋可以使用BAE和SAE,不多介紹。
3. 開(kāi)啟開(kāi)發(fā)者模式
微信公眾平臺(tái)有兩個(gè)模式,一個(gè)是編輯模式(傻瓜模式),簡(jiǎn)單但功能單一。另一個(gè)是開(kāi)發(fā)者模式,可以通過(guò)開(kāi)發(fā)實(shí)現(xiàn)復(fù)雜功能。兩個(gè)模式互斥,顯而易見(jiàn),登錄微信公眾平臺(tái)并通過(guò)“高級(jí)功能”菜單開(kāi)啟開(kāi)發(fā)者模式。
4. 填寫(xiě)接口配置信息
同樣是在“高級(jí)功能”菜單中配置,需要配置兩項(xiàng)參數(shù):
URL: 開(kāi)發(fā)者應(yīng)用訪問(wèn)地址,目前僅支持80端口,以“http://www.YoonPer.com/weixin/index.php”為例。
TOKEN: 隨意填寫(xiě),用于生成簽名,以“YoonPer”為例。
填寫(xiě)完把下面代碼保存為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是否正確接入,研究代碼沒(méi)有實(shí)質(zhì)性意義,驗(yàn)證完即可刪除文件,就不詳細(xì)說(shuō)明了,有興趣的童鞋可以查看官方文檔。
微信公眾平臺(tái)API文檔:
http://mp.weixin.qq.com/wiki/index.php
5. 開(kāi)發(fā)微信公眾平臺(tái)功能
OK,上面提到了,微信公眾平臺(tái)與開(kāi)發(fā)者之間的數(shù)據(jù)交互是通過(guò)XML完成的,既然用到XML,當(dāng)然得遵循規(guī)范,所以在著手開(kāi)發(fā)之前先看看官方接口文檔提供的XML規(guī)范,以文本消息為例:
當(dāng)用戶向微信公眾賬號(hào)發(fā)送消息時(shí),微信服務(wù)器會(huì)POST給開(kāi)發(fā)者一些數(shù)據(jù):
<xml> <!--開(kāi)發(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>
開(kāi)發(fā)者在處理完消息后需要返回?cái)?shù)據(jù)給微信服務(wù)器:
<xml> <!--接收方帳號(hào)(OpenID)--> <ToUserName><![CDATA[toUser]]></ToUserName> <!--開(kāi)發(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ā)送圖片消息、地理位置消息、鏈接消息、事件推送,而開(kāi)發(fā)者還可以向微信公眾平臺(tái)回復(fù)音樂(lè)消息和圖文消息,各類消息XML規(guī)范也可以參見(jiàn)官方文檔。
來(lái)看看官方提供的一個(gè)PHP示例,我做了一些精簡(jiǎn):
<?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過(guò)來(lái)的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/目錄,如果剛才沒(méi)刪除該文件,則直接覆蓋。
現(xiàn)在用戶通過(guò)微信公眾平臺(tái)發(fā)送任何消息公眾賬號(hào)均會(huì)返回一條內(nèi)容為“http://www.YoonPer.com”的消息。
接下來(lái)需要做的就是根據(jù)用戶消息動(dòng)態(tài)返回結(jié)果~
SimSimi(小黃雞)是目前比較火的聊天機(jī)器人,我用CURL開(kāi)發(fā)了一個(gè)免費(fèi)的SimSimi(小黃雞)接口,傳入關(guān)鍵詞會(huì)返回文本回復(fù),這部分不是本文重點(diǎn),就不多說(shuō)明,直接上代碼(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è)問(wèn)題...';
}
}
?>
把上面兩段代碼整合在一起就大功告成了,需要說(shuō)明一點(diǎn),微信服務(wù)器在5秒內(nèi)收不到響應(yīng)會(huì)斷掉連接,通過(guò)此接口有可能會(huì)超時(shí),且SimSimi已經(jīng)屏蔽了BAE和SAE上的抓取請(qǐng)求,推薦使用SimSimi官方收費(fèi)API,速度比較快~
希望本文所述對(duì)大家基于php的微信公眾平臺(tái)開(kāi)發(fā)有所幫助。
- php版微信公眾平臺(tái)之微信網(wǎng)頁(yè)登陸授權(quán)示例
- PHP實(shí)現(xiàn)微信網(wǎng)頁(yè)授權(quán)開(kāi)發(fā)教程
- 微信網(wǎng)頁(yè)授權(quán)(OAuth2.0) PHP 源碼簡(jiǎn)單實(shí)現(xiàn)
- weiphp微信公眾平臺(tái)授權(quán)設(shè)置
- PHP實(shí)現(xiàn)微信小程序用戶授權(quán)的工具類示例
- php判斷頁(yè)面是否是微信打開(kāi)的示例(微信打開(kāi)網(wǎng)頁(yè))
- PHP對(duì)接微信公眾平臺(tái)消息接口開(kāi)發(fā)流程教程
- php實(shí)現(xiàn)微信公眾平臺(tái)賬號(hào)自定義菜單類
- PHP版微信第三方實(shí)現(xiàn)一鍵登錄及獲取用戶信息的方法
- PHP微信網(wǎng)頁(yè)授權(quán)的配置文件操作分析
相關(guān)文章
TP5框架實(shí)現(xiàn)的數(shù)據(jù)庫(kù)備份功能示例
這篇文章主要介紹了TP5框架實(shí)現(xiàn)的數(shù)據(jù)庫(kù)備份功能,結(jié)合實(shí)例形式分析了TP5數(shù)據(jù)庫(kù)備份功能相關(guān)原理及實(shí)現(xiàn)方法,需要的朋友可以參考下2020-04-04
PHP輸出當(dāng)前進(jìn)程所有變量/常量/模塊/函數(shù)/類的示例
PHP輸出當(dāng)前進(jìn)程所有變量、常量、模塊、函數(shù)、類的示例2013-11-11
PHP如何實(shí)現(xiàn)阿里云短信sdk靈活應(yīng)用在項(xiàng)目中的方法
這篇文章主要介紹了PHP如何實(shí)現(xiàn)阿里云短信sdk靈活應(yīng)用在項(xiàng)目中的方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2019-06-06
wampserver改變默認(rèn)網(wǎng)站目錄的辦法
大家在做php項(xiàng)目時(shí),很多項(xiàng)目都會(huì)用到wampserver。WampServe集成了Apache、MySQL、PHP、phpmyadmin,支持Apache的mod_rewrite,PHP擴(kuò)展、Apache模塊只需要在菜單“開(kāi)啟/關(guān)閉”上點(diǎn)點(diǎn)就搞定,省去了修改配置文件的麻煩,這里就簡(jiǎn)寫(xiě)成wamp。2015-08-08
PHP對(duì)接微信公眾平臺(tái)消息接口開(kāi)發(fā)流程教程
這篇文章主要介紹了PHP對(duì)接微信公眾平臺(tái)消息接口開(kāi)發(fā)流程,如何使用PHP版接口操作公眾平臺(tái)消息,需要的朋友可以參考下2014-03-03
ThinkPHP中泛域名部署的實(shí)現(xiàn)方法
對(duì)于需要部署多個(gè)網(wǎng)站的開(kāi)發(fā)者來(lái)說(shuō),站群架構(gòu)是一種廣泛采用的設(shè)計(jì)模式,而泛域名部署則是站群架構(gòu)中比較常見(jiàn)的實(shí)現(xiàn)方式之一,在這篇文章中,我們將介紹如何在ThinkPHP框架中實(shí)現(xiàn)泛域名部署站群,需要的朋友可以參考下2024-04-04
codeigniter框架The URI you submitted has disallowed characters
這篇文章主要介紹了codeigniter框架The URI you submitted has disallowed characters錯(cuò)誤解決方法,需要的朋友可以參考下2014-05-05

