本文實例講述了基于php的微信公眾平臺開發(fā)方法。分享給大家供大家參考。具體如下:
最近在做微信公眾平臺開發(fā),一口氣寫了二十幾個功能,挺有意思的~
今天來分享一下開發(fā)經驗~
微信公眾平臺提供的接口很簡單,先看看消息交互流程:
說的通俗一些,用戶使用微信發(fā)送消息 -> 微信將數(shù)據發(fā)送給開發(fā)者 -> 開發(fā)者處理消息并返回數(shù)據至微信 -> 微信把返回數(shù)據發(fā)送給用戶,期間數(shù)據交互通過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/目錄,最后點擊“提交”完成驗證。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
|
<?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是否正確接入,研究代碼沒有實質性意義,驗證完即可刪除文件,就不詳細說明了,有興趣的童鞋可以查看官方文檔。
微信公眾平臺API文檔:
http://mp.weixin.qq.com/wiki/index.php
5. 開發(fā)微信公眾平臺功能
OK,上面提到了,微信公眾平臺與開發(fā)者之間的數(shù)據交互是通過XML完成的,既然用到XML,當然得遵循規(guī)范,所以在著手開發(fā)之前先看看官方接口文檔提供的XML規(guī)范,以文本消息為例:
當用戶向微信公眾賬號發(fā)送消息時,微信服務器會POST給開發(fā)者一些數(shù)據:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
< xml > <!--開發(fā)者微信號--> < ToUserName > <![CDATA[toUser]]> </ ToUserName > <!--發(fā)送方帳號(OpenID)--> < FromUserName > <![CDATA[fromUser]]> </ FromUserName > <!--消息創(chuàng)建時間 (整型)--> < CreateTime >12345678</ CreateTime > <!--消息類別 (text文本消息)--> < MsgType ><![CDATA1]></ MsgType > <!--消息內容--> < Content > <![CDATA[content]]> </ Content > <!--消息ID (64位整型)--> < MsgId >1234567890123456</ MsgId > </ xml > |
開發(fā)者在處理完消息后需要返回數(shù)據給微信服務器:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
< xml > <!--接收方帳號(OpenID)--> < ToUserName > <![CDATA[toUser]]> </ ToUserName > <!--開發(fā)者微信號--> < FromUserName > <![CDATA[fromUser]]> </ FromUserName > <!--消息創(chuàng)建時間 (整型)--> < CreateTime >12345678</ CreateTime > <!--消息類別 (text文本消息)--> < MsgType ><![CDATA1]></ MsgType > <!--回復消息內容--> < Content > <![CDATA[content]]> </ Content > <!--星標操作(位0x0001被標志時 星標剛收到的消息)--> < FuncFlag >0</ FuncFlag > </ xml > |
除文本消息外,微信公眾平臺還支持用戶發(fā)送圖片消息、地理位置消息、鏈接消息、事件推送,而開發(fā)者還可以向微信公眾平臺回復音樂消息和圖文消息,各類消息XML規(guī)范也可以參見官方文檔。
來看看官方提供的一個PHP示例,我做了一些精簡:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
|
<?php /*------------------------------------------------- | index.php [ 微信公眾平臺接口 ] +-------------------------------------------------- | Author: LimYoonPer +------------------------------------------------*/ $wechatObj = new wechat(); $wechatObj ->responseMsg(); class wechat { public function responseMsg() { //---------- 接 收 數(shù) 據 ---------- // $postStr = $GLOBALS [ "HTTP_RAW_POST_DATA" ]; //獲取POST數(shù)據 //用SimpleXML解析POST過來的XML數(shù)據 $postObj = simplexml_load_string( $postStr , 'SimpleXMLElement' ,LIBXML_NOCDATA); $fromUsername = $postObj ->FromUserName; //獲取發(fā)送方帳號(OpenID) $toUsername = $postObj ->ToUserName; //獲取接收方賬號 $keyword = trim( $postObj ->Content); //獲取消息內容 $time = time(); //獲取當前時間戳 //---------- 返 回 數(shù) 據 ---------- // //返回消息模板 $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 ); //返回消息內容 //格式化消息模板 $resultStr = sprintf( $textTpl , $fromUsername , $toUsername , $time , $msgType , $contentStr ); echo $resultStr ; //輸出結果 } } ?> |
把代碼保存為index.php并上傳至http://www.YoonPer.com/weixin/目錄,如果剛才沒刪除該文件,則直接覆蓋。
現(xiàn)在用戶通過微信公眾平臺發(fā)送任何消息公眾賬號均會返回一條內容為“http://www.YoonPer.com”的消息。
接下來需要做的就是根據用戶消息動態(tài)返回結果~
SimSimi(小黃雞)是目前比較火的聊天機器人,我用CURL開發(fā)了一個免費的SimSimi(小黃雞)接口,傳入關鍵詞會返回文本回復,這部分不是本文重點,就不多說明,直接上代碼(2014.07.28更新):
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
|
<?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 ); //----------- 抓 取 回 復 ----------// $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秒內收不到響應會斷掉連接,通過此接口有可能會超時,且SimSimi已經屏蔽了BAE和SAE上的抓取請求,推薦使用SimSimi官方收費API,速度比較快~
希望本文所述對大家基于php的微信公眾平臺開發(fā)有所幫助。