1. 程式人生 > >微信開發模式之自己定義菜單實現

微信開發模式之自己定義菜單實現

ces event pre api pid 開發人員 web weixin src

編輯模式和開發模式是有沖突的。所以我們啟用微信公眾號的開發模式之後。那些菜單是看不到的哦。

只是如今個人訂閱號是不能夠使用高級開發人員模式的。如自己定義菜單,只是我們還是能夠通過測試號來測試一下。然後移代碼到服務號。

自己定義類型包含例如以下:
1、click:點擊推事件
? 用戶點擊click類型button後。微信server會通過消息接口推送消息類型為event
的結構給開發人員(參考消息接口指南)。而且帶上button中開發人員填寫的key值
,開發人員能夠通過自己定義的key值與用戶進行交互。
2、view:跳轉URL
? 用戶點擊view類型button後,微信client將會打開開發人員在button中填寫的網頁
URL,可與網頁授權獲取用戶基本信息接口結合,獲得用戶基本信息。
3、scancode_push:掃碼推事件
? 用戶點擊button後,微信client將調起掃一掃工具,完畢掃碼操作後顯示掃描
結果(假設是URL,將進入URL),且會將掃碼的結果傳給開發人員,開發人員可
下面發消息。


4、scancode_waitmsg:掃碼推事件且彈出“消息接收中”提示框
? 用戶點擊button後,微信client將調起掃一掃工具。完畢掃碼操作後,將掃碼
的結果傳給開發人員,同一時候收起掃一掃工具,然後彈出“消息接收中”提示框
,隨後可能會收到開發人員下發的消息。

自己定義類型包含例如以下:
5、pic_sysphoto:彈出系統拍照發圖用戶點擊button後,微信
client將調起系統相機,完畢拍照操作後,會將拍攝的相片
發送給開發人員,並推送事件給開發人員,同一時候收起系統相機。
隨後可能會收到開發人員下發的消息。
6、pic_photo_or_album:彈出拍照或者相冊發圖用戶點擊按
鈕後。微信client將彈出選擇器供用戶選擇“拍照”或者“
從手機相冊選擇”。用戶選擇後即走其它兩種流程。
7、pic_weixin:彈出微信相冊發圖器用戶點擊button後。微信
client將調起微信相冊,完畢選擇操作後。將選擇的相片發
送給開發人員的server。並推送事件給開發人員,同一時候收起相冊
,隨後可能會收到開發人員下發的消息。


提供代碼,僅僅要上傳代碼到server,又一次關註公眾號就能夠看到開發模式下的自己定義菜單

$appid = '微信公眾號的appid';
$appsecret = '微信公眾號的appsecret';
$url = "https://api.weixin.qq.com/cgi-bin/token?

grant_type=client_credential&appid={$appid}&secret=$appsecret"; $output = https_request($url); $jsoninfo = json_decode($output,true); $access_token = $jsoninfo["access_token"]; $jsonmenu = '{ "button":[ { "name":"學校系統", "sub_button":[ { "type":"click", "name":"課程表", "key":"課程表" }, { "type":"click", "name":"個人信息", "key":"個人信息" }, { "type":"click", "name":"平時成績", "key":"平時成績" }, { "type":"click", "name":"獎懲記錄", "key":"獎懲記錄" } ] }, { "name":"技術分享", "sub_button":[ { "type":"click", "name":"移動WEB開發", "key":"移動WEB開發" }, { "type":"click", "name":"J2EE框架", "key":"J2EE框架" }, { "type":"click", "name":"Android開發", "key":"Android開發" }, { "type":"click", "name":"PHP框架", "key":"PHP框架" } ] },{ "name":"技術支持", "sub_button":[ { "type":"click", "name":"在線客服", "key":"在線客服" }, { "type":"click", "name":"技術分享", "key":"技術分享" }, { "type":"view", "name":"天氣預報", "url":"http://m.hao123.com/a/tianqi" } ] } ] }'; //創建菜單實現 $url = 'https://api.weixin.qq.com/cgi-bin/menu/create?access_token='.$access_token; $result = https_request($url,$jsonmenu); var_dump($result); function https_request($url,$data = null){ $curl = curl_init(); curl_setopt($curl,CURLOPT_URL,$url); curl_setopt($curl,CURLOPT_SSL_VERIFYPEER,0); curl_setopt($curl,CURLOPT_SSL_VERIFYHOST,0); if(!empty($data)){ curl_setopt($curl,CURLOPT_POST,1); curl_setopt($curl,CURLOPT_POSTFIELDS,$data); } curl_setopt($curl,CURLOPT_RETURNTRANSFER,1); $output = curl_exec($curl); curl_close($curl); return $output; }


技術分享





微信開發模式之自己定義菜單實現