**目录 (Table of Contents)**
[TOC]
## 创建微信菜单
```PHP
// 我们现在添加3个微信一级菜单,每个一级菜单下添加两个二级菜单
// 菜单结构如下
// --- 团购 click
// | -------- 团购简介 click 事件推送
// | -------- 团购预约 view 跳转
// --- 我的 click
// | ------- 我的钱包 view 跳转
// | ------- 我的订单 view 跳转
// --- 购票 click
// | ------ 预约购票 view 跳转
// | ------ 票务说明 view 跳转
$wxConfigure = new WechatConfig();
$wxConfigure->setParameter("appid",YoursAppId );
$wxConfigure->setParameter("appsecret",YoursSecret);
$wxConfigure->setParameter("access_token",ACCESS_TOKEN);
$menuApi = new MenuApi($wxConfigure);
// 添加 团购一级菜单
$fristMenu = new ClickMenu("团购");
// 添加 团购简介 和 团购预约 二级菜单
$fristMenu->addChild(new ClickMenu("团购简介","groupbuy info"))
->addChild(new ViewMenu("团购预约","https://github.com/DarthAhsoka/Endor-Wechat"));
// 添加 我的一级菜单
$secondMenu = new ClickMenu("我的");
$secondMenu->addChild(new ViewMenu("我的钱包","https://github.com/DarthAhsoka/Endor-Wechat"))
->addChild(new ViewMenu("我的订单","https://github.com/DarthAhsoka/Endor-Wechat"));
// 添加 购票一级菜单
$thirdMenu = new ClickMenu("购票");
// 也可以不使用连贯操作
$markTicket = new ViewMenu("预约购票");
$markTicket->setUrl("https://github.com/DarthAhsoka/Endor-Wechat");
$thirdMenu->addChild($markTicket);
$ticketInfo = new ViewMenu("票务说明");
$ticketInfo->setUrl("https://github.com/DarthAhsoka/Endor-Wechat");
$thirdMenu->addChild($ticketInfo);
$menuApi = new MenuApi($wxConfigure);
$menuApi->addMenuItem($fristMenu);
$menuApi->addMenuItem($secondMenu);
$menuApi->addMenuItem($thirdMenu);
// 创建菜单,调用函数后,将修改微信公众号上的菜单
try {
$menuApi->create();
}
catch(WechatException $e)
{
echo $e->errorMessage();
}
```
## 从微信公众号服务器上获取菜单,并遍历,识别菜单类型和名字
```PHP
$wxConfigure = new WechatConfig();
$wxConfigure->setParameter("appid",YoursAppId );
$wxConfigure->setParameter("appsecret",YoursSecret);
$wxConfigure->setParameter("access_token",ACCESS_TOKEN);
$menuApi = new MenuApi($wxConfigure);
try
{
$ret = $menuApi->get();
if($ret)
{
foreach ($menuArr as $v)
{
// 这里获取一级菜单,getName获取到菜单名字,getType可获取菜单类型
echo $v->getName() . " (" .$v->getType() . " )" ;
echo "\r\n";
$children = $v->getChildren();
foreach($children as $n)
{
// 这里获取二级菜单,
echo "\t\t".$n->getName() . " (" .$n->getType() . " )" ;
echo "\r\n";
}
}
}
}
catch(WechatException $e)
{
echo $e->errorMessage();
}
```
## 删除所有微信菜单
```PHP
$wxConfigure = new WechatConfig();
$wxConfigure->setParameter("appid",YoursAppId );
$wxConfigure->setParameter("appsecret",YoursSecret);
$wxConfigure->setParameter("access_token",ACCESS_TOKEN);
$menuApi = new MenuApi($wxConfigure);
$menuApi->delete();
```
- 1、序言
- 1.1、更新说明
- 1.2、更新计划
- 2、开始使用 Endor
- 3、目录结构
- 4、类说明
- 4.1、WechatConfig
- 4.2、WechatValid
- 4.3、WechatCommon
- 4.4、WechatException
- 4.5、基础接口
- 4.5.1、ShortUrl
- 4.5.2、WechatServerApi
- 4.6、菜单接口
- 4.6.1、菜单类设计
- 4.6.2、Menu
- 4.6.3、ClickMenu
- 4.6.4、ViewMenu
- 4.6.5、MiniProgramMenu
- 4.6.6、MenuApi
- 4.7、消息接口
- 4.7.1、Receiver
- 4.7.2、Message
- 4.7.3、EventMessage
- 4.7.4、TextMessage
- 4.7.5、ClickEventMessage
- 4.7.6、SubscribeEventMessage
- 4.7.7、UnSubscribeEventMessage
- 4.7.8、LocationEventMessage
- 4.7.9、ImageMessage
- 4.7.10、LinkMessage
- 4.7.11、NewsMessage
- 4.7.12、NewsContext
- 4.8、OAuth2.0权限验证
- 4.8.1、WechatUser
- 4.8.2、OAuthApi
- 4.9、微信支付接口
- 4.9.1、微信支付类设计
- 4.9.2、PayApi
- 4.9.3、RequestPay
- 4.9.4、ResponsePay
- 4.9.5、UnifiedOrder
- 4.9.6、JsPay
- 4.9.7、Refund
- 4.9.8、Query
- 4.9.9、Bill
- 4.9.10、NotifyData
- 4.9.11、Notify
- 4.10、模板消息接口
- 4.10.1、TemplateContext
- 4.10.2、TemplateMessageApi
- 5、使用场景
- 5.1、微信接入服务器验证
- 5.2、获取微信API令牌(access_token)
- 5.3、获取JS API
- 5.4、OAuth2.0静默登录
- 5.5、微信菜单
- 5.6、微信消息
- 5.7、微信支付
- 5.7.1、微信公众号内JsApi支付
- 5.7.2、Native 模式二 扫码支付
- 5.8、模板消息发送