1. 程式人生 > >微信公眾平臺開發(十) 訊息回覆總結

微信公眾平臺開發(十) 訊息回覆總結

一、簡介

微信公眾平臺提供了三種訊息回覆的格式,即文本回復、音樂回覆和圖文回覆,在這一篇文章中,我們將對這三種訊息回覆的格式做一下簡單講解,然後封裝成函式,以供讀者使用。

二、思路分析

對於每一個POST請求,開發者在響應包中返回特定xml結構,對該訊息進行響應(現支援回覆文字、圖文、語音、視訊、音樂)。

三、文本回復

3.1 文本回復xml 結構

複製程式碼
 <xml>
 <ToUserName><![CDATA[toUser]]></ToUserName>
 <FromUserName><![CDATA[fromUser
]]></FromUserName> <CreateTime>12345678</CreateTime> <MsgType><![CDATA[text]]></MsgType> <Content><![CDATA[content]]></Content> </xml>
複製程式碼

3.2 結構說明

3.3 具體實施

針對上面給出的xml 結構,我們只需要在對應的位置填上內容,然後格式化輸出就可以了。

說明:

ToUserName 位置上填寫的是$fromUsername = $postObj->FromUserName,就是把訊息返回給傳送資訊過來的使用者,即接收方賬號。

FromUserName 位置上填寫的是$toUsername = $postObj->ToUserName,既是開發者微訊號。

這是官方的文本回復,只需例項化它的responseMsg() 方法就可以回覆 “Welcome to wechat world!” 訊息了。

這裡我們稍做修改,返回fromUsername 和toUsername 訊息,便於讀者理解以上的說明。

3.4 測試結果

3.5 封裝成可呼叫的函式

我們可以將上面的內容封裝成函式,在需要回覆文本的地方直接呼叫,方便簡潔,responseText.func.inc.php 程式碼如下。

複製程式碼
function
_response_text($object,$content){ $textTpl = "<xml> <ToUserName><![CDATA[%s]]></ToUserName> <FromUserName><![CDATA[%s]]></FromUserName> <CreateTime>%s</CreateTime> <MsgType><![CDATA[text]]></MsgType> <Content><![CDATA[%s]]></Content> <FuncFlag>%d</FuncFlag> </xml>"; $resultStr = sprintf($textTpl, $object->FromUserName, $object->ToUserName, time(), $content, $flag); return $resultStr; }
複製程式碼

這樣,只要傳入$object 和$content,然後在需要回覆文本的檔案中引入該檔案,然後呼叫 _response_text() 方法,就可以直接回覆文本了。 

3.6 測試程式碼

3.6.1 在主檔案中引入回覆文字的函式檔案

require_once 'responseText.func.inc.php';

3.6.2 普通訊息回覆

複製程式碼
public function handleText($postObj)
    {
        $keyword = trim($postObj->Content);

        if(!empty( $keyword ))
        {
$contentStr = "微信公眾平臺-文本回復功能原始碼"; //$resultStr = sprintf($textTpl, $fromUsername, $toUsername, $time, $msgType, $contentStr); $resultStr = _response_text($postObj,$contentStr); echo $resultStr; }else{ echo "Input something..."; } }
複製程式碼

3.6.3 關注時回覆

複製程式碼
public function handleEvent($object)
    {
        $contentStr = "";
        switch ($object->Event)
        {
            case "subscribe":
                $contentStr = "感謝您關注【卓錦蘇州】"."\n"."微訊號:zhuojinsz";
                break;
            default :
                $contentStr = "Unknow Event: ".$object->Event;
                break;
        }
        $resultStr = _response_text($object, $contentStr);
        return $resultStr;
}
複製程式碼

3.7 測試結果

回覆文字成功。

四、圖文回覆

4.1 圖文回覆xml 結構

複製程式碼
 <xml>
 <ToUserName><![CDATA[toUser]]></ToUserName>
 <FromUserName><![CDATA[fromUser]]></FromUserName>
 <CreateTime>12345678</CreateTime>
 <MsgType><![CDATA[news]]></MsgType>
 <ArticleCount>2</ArticleCount>
 <Articles>
 <item>
 <Title><![CDATA[title1]]></Title> 
 <Description><![CDATA[description1]]></Description>
 <PicUrl><![CDATA[picurl]]></PicUrl>
 <Url><![CDATA[url]]></Url>
 </item>
 <item>
 <Title><![CDATA[title]]></Title>
 <Description><![CDATA[description]]></Description>
 <PicUrl><![CDATA[picurl]]></PicUrl>
 <Url><![CDATA[url]]></Url>
 </item>
 </Articles>
 </xml> 
複製程式碼

4.2 結構說明

類似文本回復的格式,只需要在相應的位置填上對應的內容就可以回覆圖文資訊了。

4.3 具體實施

圖文回覆可以是單圖文,也可以是多圖文,這裡我們先以單圖文的案例來引導讀者,然後再引出多圖文。

我們將回復圖文的xml 結構分解成為以下三個結構,圖文頭,圖文體,圖文尾,圖文體就是圖文回覆時看到的標題,描述,圖片URL和原文URL。

複製程式碼
$newsTplHead = "<xml>
                <ToUserName><![CDATA[%s]]></ToUserName>
                <FromUserName><![CDATA[%s]]></FromUserName>
                <CreateTime>%s</CreateTime>
                <MsgType><![CDATA[news]]></MsgType>
                <ArticleCount>1</ArticleCount>
                <Articles>";
$newsTplBody = "<item>
                <Title><![CDATA[%s]]></Title> 
                <Description><![CDATA[%s]]></Description>
                <PicUrl><![CDATA[%s]]></PicUrl>
                <Url><![CDATA[%s]]></Url>
                </item>";
$newsTplFoot = "</Articles>
                <FuncFlag>0</FuncFlag>
                </xml>";
複製程式碼

接下來,我們對三段結構分別插入對應內容:

A. $newsTplHead

$header = sprintf($newsTplHead, $object->FromUserName, $object->ToUserName, time());

B. $newsTplBody

$title = $newsContent['title'];
$desc = $newsContent['description'];
$picUrl = $newsContent['picUrl'];
$url = $newsContent['url'];
$body = sprintf($newsTplBody, $title, $desc, $picUrl, $url);

說明:$newsContent 是從主檔案傳入函式的圖文陣列。

C. $newsTplFoot

$FuncFlag = 0;
$footer = sprintf($newsTplFoot, $FuncFlag);

然後將三段進行拼接返回就可以回覆單條圖文了。

return $header.$body.$footer;

將以上內容寫到一個函式裡,命名為 _response_news() 函式,以供下面呼叫測試。

4.4 測試程式碼

4.4.1 在主檔案中引入回覆圖文的函式檔案

require_once 'responseNews.func.inc.php';

4.4.2 建立陣列並傳入

在主檔案中,只需要向 _response_news() 函式中傳入一個數組和$postObj 即可。

複製程式碼
$record=array(
    'title' =>'山塘街',
    'description' =>'山塘街東起閶門渡僧橋,西至蘇州名勝虎丘山的望山橋,長約七裡,所以蘇州俗語說“七裡山塘到虎丘”...',
    'picUrl' => 'http://thinkshare.duapp.com/images/suzhou.jpg',
    'url' =>'http://mp.weixin.qq.com/mp/appmsg/show?__biz=MjM5NDM0NTEyMg==&appmsgid=10000046&itemidx=1&sign=9e7707d5615907d483df33ee449b378d#wechat_redirect'
);

$resultStr = _response_news($postObj,$record);
echo $resultStr;
複製程式碼

4.5 測試結果

點選進入檢視

單圖文回覆測試成功。

4.6 多圖文回覆

有了上面的引導,讀者應該能夠想到回覆多圖文的思路了,就是將多維陣列中的值迴圈放到相應的位置,然後拼接起來就可以了,下面進行講解。 

4.6.1 獲取圖文條數

$bodyCount = count($newsContent);

4.6.2 判斷圖文條數

因為微信限制了回覆的圖文訊息數為10條以內,所以需要判斷圖文條數,如果小於10條,則圖文數等於原來的圖文數,如果大於等於10條,則強制限制為10條。

$bodyCount = $bodyCount < 10 ? $bodyCount : 10;

4.6.3 組織圖文體

圖文頭和圖文尾和上面單圖文一樣,不再贅述,主要是圖文體的組織。

用foreach 迴圈出陣列的內容並賦予圖文體,並進行拼接:

foreach($newsContent as $key => $value){
    $body .= sprintf($newsTplBody, $value['title'], $value['description'], $value['picUrl'], $value['url']);
}

說明:$newsContent 是從主檔案傳入函式的圖文陣列。

4.6.4 拼接並返回

return $header.$body.$footer;

將以上內容寫到一個函式裡,命名為 _response_multiNews() 函式,以供下面呼叫測試。

4.7 測試多圖文

4.7.1 在主檔案中引入回覆多圖文的函式檔案

require_once 'responseMultiNews.func.inc.php';

4.7.2 建立多維陣列並傳入

複製程式碼
$record[0]=array(
    'title' =>'觀前街',
    'description' =>'觀前街位於江蘇蘇州市區,是成街於清朝時期的百年商業老街,街上老店名店雲集,名聲遠播海內外...',
    'picUrl' => 'http://joythink.duapp.com/images/suzhou.jpg',
    'url' =>'http://mp.weixin.qq.com/mp/appmsg/show?__biz=MjM5NDM0NTEyMg==&appmsgid=10000052&itemidx=1&sign=90518631fd3e85dd1fde7f77c04e44d5#wechat_redirect'
);

......

$record[11]=array(
    'title' =>'平江路',
    'description' =>'平江路位於蘇州古城東北,是一條傍河的小路,北接拙政園,南眺雙塔,全長1606米,是蘇州一條歷史攸久的經典水巷。宋元時候蘇州又名平江,以此名路...',
    'picUrl' => 'http://joythink.duapp.com/images/suzhouScenic/pingjianglu.jpg',
    'url' =>'http://mp.weixin.qq.com/mp/appmsg/show?__biz=MjM5NDM0NTEyMg==&appmsgid=10000056&itemidx=1&sign=ef18a26ce78c247f3071fb553484d97a#wechat_redirect'
);

$resultStr = _response_multiNews($postObj,$record);
echo $resultStr;
複製程式碼

4.8 測試多圖文結果

點選進入檢視

測試多圖文成功。

五、音樂回覆

微信還提供了一種訊息回覆的格式,即音樂回覆,下面我們編寫程式測試一下。

注意:由於音樂版權的問題,現在很少有回覆音樂的API,開放的API 查詢出來的音樂資訊也有很多是不正確的。所以在這裡,我們上傳幾首音樂到自己的伺服器空間測試。

本地檔案:

測試是否能夠正常播放:

5.1 音樂回覆xml 結構

複製程式碼
 <xml>
 <ToUserName><![CDATA[toUser]]></ToUserName>
 <FromUserName><![CDATA[fromUser]]></FromUserName>
 <CreateTime>12345678</CreateTime>
 <MsgType><![CDATA[music]]></MsgType>
 <Music>
 <Title><![CDATA[TITLE]]></Title>
 <Description><![CDATA[DESCRIPTION]]>