基于php的微信公眾平臺開發(fā)入門實例
本文實例講述了基于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認(rèn)證,請慎重注冊。
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ì)性意義,驗證完即可刪除文件,就不詳細(xì)說明了,有興趣的童鞋可以查看官方文檔。
微信公眾平臺API文檔:
http://mp.weixin.qq.com/wiki/index.php
5. 開發(fā)微信公眾平臺功能
OK,上面提到了,微信公眾平臺與開發(fā)者之間的數(shù)據(jù)交互是通過XML完成的,既然用到XML,當(dāng)然得遵循規(guī)范,所以在著手開發(fā)之前先看看官方接口文檔提供的XML規(guī)范,以文本消息為例:
當(dāng)用戶向微信公眾賬號發(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> <!--星標(biāo)操作(位0x0001被標(biāo)志時 星標(biāo)剛收到的消息)--> <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(); //獲取當(dāng)前時間戳
//---------- 返 回 數(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ā)有所幫助。
- php版微信公眾平臺之微信網(wǎng)頁登陸授權(quán)示例
- PHP實現(xiàn)微信網(wǎng)頁授權(quán)開發(fā)教程
- 微信網(wǎng)頁授權(quán)(OAuth2.0) PHP 源碼簡單實現(xiàn)
- weiphp微信公眾平臺授權(quán)設(shè)置
- PHP實現(xiàn)微信小程序用戶授權(quán)的工具類示例
- php判斷頁面是否是微信打開的示例(微信打開網(wǎng)頁)
- PHP對接微信公眾平臺消息接口開發(fā)流程教程
- php實現(xiàn)微信公眾平臺賬號自定義菜單類
- PHP版微信第三方實現(xiàn)一鍵登錄及獲取用戶信息的方法
- PHP微信網(wǎng)頁授權(quán)的配置文件操作分析
相關(guān)文章
用Laravel Sms實現(xiàn)laravel短信驗證碼的發(fā)送的實現(xiàn)
這篇文章主要介紹了用Laravel Sms實現(xiàn)laravel短信驗證碼的發(fā)送的實現(xiàn),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-11-11
基于php解決json_encode中文UNICODE轉(zhuǎn)碼問題
這篇文章主要介紹了基于php解決json_encode中文UNICODE轉(zhuǎn)碼問題,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-11-11

