微信公眾號開發分傻瓜模式和開發者模式兩種,前者不要考慮調用某些接口,只要根據后臺提示傻瓜式操作即可,適用于非專業開發人員。
開發模式當然就是懂程序開發的人員使用的。
下面簡單說一下微信公眾號開發的簡易流程,新手看看會有幫助,高手請一笑而過。
1、配置服務器:
A、首先在本機建立如下結構的文件夾(這里是我自己的習慣,僅供參考)
MMPN:總目錄mro message html' target='_blank'>public number 微信公眾號
backup:備份目錄,主要用于備份php文件,每次修改時將原稿備份到里面去。
images:存放圖片
includes:包含文件,包括mysql配置,smarty模板包含文件等等
menu:存放公眾號菜單信息,txt文檔即可
gr****zx.php:開發文件,即公眾號關聯的程序文件,也就是配置的url對應的文件
最后的是需求等等的文件
主程序文件:gr****zx.php
1 <?php 2 3 define('TOKEN', 'aabbc_lzpt'); 4 5 //獲取微信發送數據 6 $postStr = $GLOBALS['HTTP_RAW_POST_DATA']; 7 //返回回復數據 8 if (!empty($postStr)) 9 { 10 //解析數據 11 $postObj = simplexml_load_string($postStr, 'SimpleXMLElement', LIBXML_NOCDATA); 12 //發送消息方ID 13 $fromUsername = $postObj->FromUserName; 14 //接送消息方ID 15 $toUsername = $postObj->ToUserName; 16 //消息類型 17 $form_MsgType = $postObj->MsgType; 18 19 //事件消息 20 if($form_MsgType=='event') 21 { 22 //獲取事件類型 23 $form_Event = $postObj->Event; 24 //訂閱事件 25 if($form_Event=='subscribe') 26 { 27 28 //回復歡迎圖文信息 29 /* 30 $resultStr = '<xml> 31 <ToUserName><![CDATA['.$fromUsername.']]></ToUserName> 32 <FromUserName><![CDATA['.$toUsername.']]></FromUserName> 33 <CreateTime>'.time().'</CreateTime> 34 <MsgType><![CDATA[news]]></MsgType> 35 <ArticleCount>2</ArticleCount> 36 <Articles> 37 <item> 38 <Title><![CDATA[ 歡迎關注***微信服務平臺,****]]></Title> 39 <Description><![CDATA[這是簡短描述文字]]></Description> 40 <PicUrl><![CDATA[http://a.hiphotos.baidu.com/baike/c0%3Dbaike116%2C5%2C5%2C116%2C38/sign=5cae7405f21f3a294ec5dd9cf84cd754/32fa828ba61ea8d32de5a1df950a304e241f5822.jpg]]></PicUrl> 41 <Url><![CDATA[http://www.baidu.com]]></Url> </item> 42 <item> 43 <Title><![CDATA[最新動態]]></Title> 44 <Description><![CDATA[]]></Description> 45 <PicUrl><![CDATA[http://a.hiphotos.baidu.com/baike/c0%3Dbaike116%2C5%2C5%2C116%2C38/sign=5cae7405f21f3a294ec5dd9cf84cd754/32fa828ba61ea8d32de5a1df950a304e241f5822.jpg]]></PicUrl> 46 <Url><![CDATA[http://www.baidu.com]]></Url> </item> 47 48 </Articles> 49 </xml> '; 50 */ 51 //回復歡迎文字信息 52 53 $reply='您好,歡迎關注******微信公眾平臺'; 54 $resultStr='<xml> 55 <ToUserName><![CDATA['.$fromUsername.']]></ToUserName> 56 <FromUserName><![CDATA['.$toUsername.']]></FromUserName> 57 <CreateTime>'.time().'</CreateTime> 58 <MsgType><![CDATA[text]]></MsgType> 59 <Content><![CDATA['.$reply.']]></Content> 60 </xml>'; 61 } 62 else if($form_Event=='CLICK') 63 { 64 $form_Event_Key = $postObj->EventKey; 65 if($form_Event_Key=='V3002_CONTACT') 66 { 67 /* 68 $resultStr = '<xml> 69 <ToUserName><![CDATA['.$fromUsername.']]></ToUserName> 70 <FromUserName><![CDATA['.$toUsername.']]></FromUserName> 71 <CreateTime>'.time().'</CreateTime> 72 <MsgType><![CDATA[news]]></MsgType> 73 <ArticleCount>1</ArticleCount> 74 <Articles> 75 <item> 76 <Title><![CDATA[如何成為本站會員]]></Title> 77 <Description><![CDATA[本欄目介紹詳細的加入流程!]]></Description> 78 <PicUrl><![CDATA[http://a.hiphotos.baidu.com/baike/c0%3Dbaike116%2C5%2C5%2C116%2C38/sign=5cae7405f21f3a294ec5dd9cf84cd754/32fa828ba61ea8d32de5a1df950a304e241f5822.jpg]]></PicUrl> 79 <Url><![CDATA[http://www.baidu.com]]></Url> 80 </item> 81 </Articles> 82 </xml> '; 83 */ 84 $reply='我們的地址:黃河東路222號我們的熱線:0510-88888888'; 85 $resultStr='<xml> 86 <ToUserName><![CDATA['.$fromUsername.']]></ToUserName> 87 <FromUserName><![CDATA['.$toUsername.']]></FromUserName> 88 <CreateTime>'.time().'</CreateTime> 89 <MsgType><![CDATA[text]]></MsgType> 90 <Content><![CDATA['.$reply.']]></Content> 91 </xml>'; 92 } 93 } 94 95 } 96 else if($form_MsgType=='location'){ 97 $lng1=$postObj->Location_X; 98 $lat1=$postObj->Location_Y; 99 $from_Location_Label=$postObj->Label;100 $reply='地理位置:';101 $reply.='緯度'.$lat1.' 經度'.$lng1.'位置'.$from_Location_Label;102 $resultStr = '<xml>103 <ToUserName><![CDATA['.$fromUsername.']]></ToUserName>104 <FromUserName><![CDATA['.$toUsername.']]></FromUserName>105 <CreateTime>'.time().'</CreateTime>106 <MsgType><![CDATA[text]]></MsgType>107 <Content><![CDATA['.$reply.']]></Content>108 </xml> '; 109 110 } 111 echo $resultStr;112 exit; 113 }114 else115 {116 echo '';117 exit;118 }119 ?>
臨時文件:wx_sample.php
<?php/** * wechat php test *///define your tokendefine('TOKEN', 'aabbc_lzpt');$wechatObj = new wechatCallbackapiTest();$wechatObj->valid();class wechatCallbackapiTest{ public function valid() { $echoStr = $_GET['echostr']; //valid signature , option if($this->checkSignature()){ echo $echoStr; exit; } } public function responseMsg() { //get post data, May be due to the different environments $postStr = $GLOBALS['HTTP_RAW_POST_DATA']; //extract post data if (!empty($postStr)){ $postObj = simplexml_load_string($postStr, 'SimpleXMLElement', LIBXML_NOCDATA); $fromUsername = $postObj->FromUserName; $toUsername = $postObj->ToUserName; $keyword = trim($postObj->Content); $time = time(); $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>'; if(!empty( $keyword )) { $msgType = 'text'; $contentStr = 'Welcome to wechat world!'; $resultStr = sprintf($textTpl, $fromUsername, $toUsername, $time, $msgType, $contentStr); echo $resultStr; }else{ echo 'Input something...'; } }else { echo ''; exit; } } private function checkSignature() { $signature = $_GET['signature']; $timestamp = $_GET['timestamp']; $nonce = $_GET['nonce']; $token = TOKEN; $tmpArr = array($token, $timestamp, $nonce); sort($tmpArr, SORT_STRING); $tmpStr = implode( $tmpArr ); $tmpStr = sha1( $tmpStr ); if( $tmpStr == $signature ){ return true; }else{ return false; } }}?>
注意看兩個文件開頭都有代碼:define('TOKEN', 'aabbc_lzpt'); 這是定義token,后面的值自己設置,但是自己要記住,在微信后臺配置服務器要用到它。
B、現在開始操作,首先,將gr****zx.php文件中的內容(代碼),臨時清空,代替以臨時文件中的內容(代碼),保存。將MMPN項目傳到服務器,這時,主程序文件url為“http://www.****.com/MMPN/fy_hzx/grape_fy_hzx.php”這樣的形式,確保路徑正確,打開微信公眾號后臺開發者中心,點擊下圖中“修改配置”,將剛才的url填入相應控件
token就是剛才提到要記住的token的值,要一致。第三個“消息加密密鑰”可以隨機生成,然后提交。
token正確和url正確以及文件代碼無誤的話,會提示成功,再點啟用。
C、剛才主程序文件中的代碼是臨時的,只是為了開通注冊驗證token,成功以后,可以再次清除,恢復成原來的內容。(保存好再上傳到服務器)
這樣服務器配置工作就結束了。
2、介紹一下主程序文件中的代碼
$form_MsgType = $postObj->MsgType;
$form_MsgType消息類型,分為“事件”、“位置”(粉絲發送位置)、“文字類型”、“圖片類型”等,具體可查看后臺接口文檔
$form_Event = $postObj->Event;
$form_Event 事件類型分為“訂閱”(subscribe)(也就是點關注)、退訂(unsubscribe)、“點擊”(CLICK)——點擊菜單,但是只針對click類型的菜單,如果是url類型的菜單,則直接打開對應的url,無須在代碼中處理。
回復粉絲的內容形式一般為文字或圖文兩種,代碼中都有。
3、菜單配置
菜單配置要知道開發者ID中的AppID(這個可以直接看到)和AppSecret(這個有可能是被隱藏的,要通過公眾號管理員驗證通過申請查看才能顯示完整,顯示完整后要及時保存記錄,這樣下次就不用再找管理員了)。
配置菜單前,首先要拿到access_token,它的有效期為2小時。如圖點擊獲取access_token
然后在右下方點擊“使用網頁調試工具調試該接口”
輸入appid和secret,點“檢查問題”提交
拷貝獲取到的access_token
重新選擇自定義菜單:
將剛獲取到的access_token 拷入
如果接口列表選擇的是查詢菜單,提交的結果是不存在,這就對了,因為我們還沒有創建菜單呢
那么,我們就創建一個,將以下json格式代碼拷入body中,提交
{ 'button': [ { 'name': '首頁', 'sub_button': [ { 'type': 'view', 'name': '注冊登錄', 'url': 'http://www.baidu.com', 'sub_button': [ ] }, { 'type': 'click', 'name': '娛樂一刻', 'key': 'V1001_QUERY', 'sub_button': [ ] }, { 'type': 'view', 'name': '查看網址', 'url': 'http://www.baidu.com', 'sub_button': [ ] } ] }, { 'name': '主頁', 'sub_button': [ { 'type': 'view', 'name': '注冊登錄', 'url': 'http://www.baidu.com', 'sub_button': [ ] }, { 'type': 'click', 'name': '娛樂一刻', 'key': 'V1001_QUERY', 'sub_button': [ ] }, { 'type': 'view', 'name': '查看網址', 'url': 'http://www.baidu.com', 'sub_button': [ ] } ] }, { 'name': '關注我們', 'sub_button': [ { 'type': 'view', 'name': '注冊登錄', 'url': 'http://www.baidu.com', 'sub_button': [ ] }, { 'type': 'click', 'name': '娛樂一刻', 'key': 'V1001_QUERY', 'sub_button': [ ] }, { 'type': 'view', 'name': '查看網址', 'url': 'http://www.baidu.com', 'sub_button': [ ] } ] } ] }
提交,提示成功菜單即生成。
菜單內容中,有兩個類型 (type),一個是view,這個會直接打開相應url鏈接;一個是click,這個就會在剛才主程序文件中尋找對應key值運行相關的代碼。
格式不要弄錯就行。
如果要修改菜單,先刪除,再創建;一般來說,菜單更改后,公眾號須重新關注才能馬上看到更改效果,否則要等24小時自動更新。
PHP編程
鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。
新聞熱點
疑難解答