# 微信公众号推送接口对接教程
[TOC]
## **第一步 创建一个控制器 继承WchatApi**
~~~
<?php
namespace app\api\controller\index;
use mikkle\tp_wechat\WechatApi;
/**
* Created by PhpStorm.
* Power By Mikkle
* Email:776329498@qq.com
* Date: 2017/11/1
* Time: 14:57
*/
class Index extends WechatApi
{
}
~~~
ok 现在微信的接口已经搭建好了 剩余就是配置微信参数了
## **第二步 配置微信参数**
配置参数详见
https://www.kancloud.cn/mikkle/thinkphp5_study/450540
当然 你也可以直接吧微信参数直接写到接口文件中
~~~
<?php
namespace app\api\controller\index;
use mikkle\tp_wechat\WechatApi;
/**
* Created by PhpStorm.
* Power By Mikkle
* Email:776329498@qq.com
* Date: 2017/11/1
* Time: 14:57
*/
class Index extends WechatApi
{
protected $options=[
'token'=>'*****',
'appid'=>'******************',
'appsecret'=>'*********************************',
'encodingaeskey'=>'******************************',
];
protected $valid = false; //网站第一次匹配 true 1为匹配
protected $isHook = false; //是否开启钩子
}
~~~
## **第三步 登录微信网站对接接口即可**
>[danger] 设置 protected $valid = true; //网站第一次匹配 true 1为匹配
> 登录微信公众平台对接即可.
## **第四步 根据自己实际需求处理重建回调方法**
例如:
~~~
protected function returnEventUnsubscribe(){
Db::name('WeFans')->where('openid', $this->openid)->update(['subscribe' => 0, 'unsubscribe_time' => time()]);
return ['type' => 'text', 'message' => '期待你的再次关注'];
}
~~~
## **推送接口 回调函数列表**
详情你可以参照 WechatApi 文件
文件中已经添加了默认处理方法
| 回调方法名称 | 回调方法作用 |
| --- | --- |
| returnMessageText | 默认文本消息回复内容 |
| returnMessageImage | 默认图片信息回复内容 |
| returnMessageVoice | 默认语音信息回复内容处理方法 |
| returnMessageMusic | 默认音乐信息回复内容处理方法 |
| returnMessageVideo | 默认视频信息回复处理方法 |
| returnMessageLocation | 默认发送地理位置回复信息处理方法 |
| returnMessageLink | 默认链接回复内容处理方法 |
| returnEventSubscribe | 默认关注回复处理方法 |
| returnEventUnsubscribe | 默认取消关注回复处理方法 |
| returnEventScan | 默认扫码事件处理方法 |
| returnEventLocation | 默认上报地理事件处理方法 |
| returnEventClick | 默认点击菜单关键字处理方法 |
| returnEventMenuScan | 菜单调用扫码事件处理方法 |
| returnEventMenuPic | 通过菜单上传图片处理方法 |
| returnEventMenuLocation | 菜单上报地理事件处理方法 |
| returnEventSendMass | 群发成功推送结果处理方法 |
| returnEventSendTemplate | 模版消息接收结果处理方法 |
| returnEvenKfSession | 客服事件处理方法 |
| returnEventCard | 卡类事件 处理方法 |
| returnEventWifiConnected | wifi连一连处理方法 |
| returnEventAroundUserSnake | 周围摇一摇事件处理方法 |
| returnEventOthers | 其他未知事件处理方法 |
>[danger] PS 不是所有的推送 都会返回给顾客信息的 如果你要通知顾客 就要主动发起推送 如模版消息
在回调方法中,我只做了回调结构处理 text news
image voice video等媒体信息 message内容要写MediaId
* 文本类型
方法一 直接回复string
~~~
return '发送的是文本信息';
~~~
方法二 回复数组
~~~
return ['type' => 'text', 'message' => '感谢你的关注'];
~~~
* 回复新闻
~~~
$newsarray = [
[
'Title' => '你的图片发送成功',
'Description' => '这是你发的图片吧',
'PicUrl' => $this->data['PicUrl'],
'Url' => $this->request->domain(),
],
];
$reply = ['type' => 'news', 'message' => $newsarray];
return $reply;
~~~
>[danger] 注意 回复结构 $newsarray是二维数组 支持多条文章
* 回复 image voice video
~~~
//回复 image
return ['type' => 'image', 'message' => $MediaId];
//回复 voice
return ['type' => 'voice', 'message' => $MediaId];
//回复 video
return ['type' => 'video', 'message' => $MediaId];
~~~
## **重构微信推送保存方法的接口**
返回true 表示消息不存在 并且保存成功
返回 fasle 表示该消息已经存在
我是分表存储的 如:下面代码
~~~
saveWeMessage(){
//根据message的获取存储的Model
$model_message = $this->getWeMessageModel();
//查询是否已经接受该消息
if (isset($this->data['MsgId'])) {
if ($model_message->infoByMsgId($this->data['MsgId'])) {
return false;
}
$model_message->editData($this->data);
}
}
~~~
如果你不保存也不查询是否存在 直接返回true
## **微信推送信息的获取**
| 属性名称 | 备注 |
| --- | --- |
| $this->app_id | 微信app_id |
| $this->options | 微信参数信息 |
| $this->openid | 用户openid |
| $this->fans | 微信fans信息 |
| $this->type | 推送类型 |
| $this->data | 微信推送信息 |
你可以根据需求直接在回调函数中调用查询使用
## **微信推送信息的调试**
~~~
$this->we_dump($reply);
~~~
>[info] 你只需要使用we_dump方法即可 会把你想要的信息转化成文本信息
## **重构获取用户信息接口**
默认的获取用户信息方法并未查库处理
推荐重构 进行查库处理
~~~
/**
* 获取用户信息
* 建议根据你的需求重写此方法
* Power: Mikkle
* Email:776329498@qq.com
* @param string $openid
* @return array|bool
*/
protected function hasSaveFans($openid = '')
{
try {
$openid = $openid ?: $this->openid;
if (empty($openid)) {
return false;
}
$fans = $this->weObj->getUserInfo($openid);
return $fans;
} catch (Exception $e) {
Log::error($e->getMessage());
return false;
}
}
~~~
## **微信推送钩子(HOOK)事件列表**
>[info] 本推送接口埋藏大量的钩子(HOOK),但并没用自动开启
>[danger] 如果要开启钩子 请将$this->isHook 设置为true 或者 1
> 另外 回调函数的参数为 $this->weObj 对象 并不是当前类
~~~
Hook::listen("wechat_receive", $this->weObj);
~~~
>[info] 你可以根据下面的方法 在hook获取想要的值
~~~
//分解数据获得常用字段
$get_rev = $this->weObj->getRev();
$this->openid = $get_rev->getRevFrom();
$this->type = $get_rev->getRevType();
$this->data = $get_rev->getRevData();
~~~
| 钩子名称 | 钩子说明 |
| --- | --- |
| wechat_receive | 主程序 |
| wechat_message_text | |
| wechat_message_image | |
| wechat_message_voice | |
| wechat_message_music | |
| wechat_message_video | |
| wechat_message_location | |
| wechat_message_link | |
| wechat_event_subscribe | |
| wechat_event_unsubscribe | |
| wechat_event_scan | |
| wechat_event_location | |
| wechat_event_click | |
| wechat_event_menu_scan_push | |
| wechat_event_menu_scan_waitmsg | |
| wechat_event_menu_pic_sys | |
| wechat_event_menu_pic_photo | |
| wechat_event_menu_pic_weixin | |
| wechat_event_menu_location | |
| wechat_event_send_mass | |
| wechat_event_send_template | |
| wechat_event_kf_create | |
| wechat_event_kf_close | |
| wechat_event_kf_switch | |
| wechat_event_card_pass | |
| wechat_event_card_notpass | |
| wechat_event_card_user_get | |
| wechat_event_menu_user_del | |
| wechat_event_wifi_connected | |
| wechat_event_around_user_shake | |
| wechat_event_others | |
注释我不写了 自己猜吧
- 序言及更新日志
- 前言一 开发PHP必备的环境(你可以不看)
- LinUX系统ThinkPHP5链接MsSQL数据库的pdo_dblib扩展
- centos7.2挂载硬盘攻略
- Centos系统Redis安装及Redis的PHP扩展安装
- Centos系统增加Swap(系统交换区)的方法
- 前言二 开发PHP软件配置和介绍(你依然可以不看)
- 数据库SQL文件
- 本地Git(版本控制)的搭建
- GIT远程仓库的克隆和推送
- Git常用命令
- PHP面向对象思想实战经验领悟
- PHP面向对象实战----命名空间
- PHP面向对象实战----继承
- 基类实战--底层方法封装
- 基类实战--构造函数实战
- 基类实战--析构函数的使用
- TP5实战开发前篇---控制器(controller)
- 控制器中Request类的使用
- 控制器中基类的使用
- TP5实战开发前篇---模型篇(model)
- TP5实战开发前篇---验证器篇(Validate)
- TP5实战课程入门篇---花拳绣腿
- 模块以及类的文件的建立
- Api开发------单条信息显示
- Api开发---单条信息复杂关联显示
- Api开发---查询信息缓存Cache的应用
- TP5实战技巧---开发思路 引路造桥
- TP5实战技巧---整合基类 化繁为简
- TP5实战课程入门篇---数据操作
- Api开发---数据的添加和修改
- API开发---快速开发API通用接口
- TP5专用微信sdk使用教程
- THINKPHP5微信SDK更新记录及升级指导
- TP5专用SDK 微信参数配置方法
- 微信公众号推送接口对接教程
- 微信推送接口对接示例含扫描登录微信端部分
- TP5专用微信支付SDK使用简介
- TP5专用支付宝支付SDK使用说明
- 使用NW将开发的网站打包成桌面应用
- TP5高阶实战课程 进阶篇概述
- 进阶篇一 实战开发之习惯及要求
- 进阶篇二 实战开发之控制器
- 控制器基类之控制器基类使用方法
- 控制器基类之控制器基类常用方法分享
- 控制器基类之构造函数的使用方法
- 进阶篇三 实战开发之权限控制
- TP5实战源码 --- 全局用户信息验证类Auth
- TP5实战源码 --- 微信Auth实战开发源码
- 进阶篇四 实战开发之模型
- 模型基类之模型基类的用途
- 模型基类之常用数据处理方法
- 模型逻辑层之实战代码(含事务)
- 模型实战开发之模型常用方法
- 模型实战源码 --- 乐观锁的应用
- 模型实战技巧---Model事件功能的使用
- 模型事件实战应用---数据库操作日志
- 进阶篇五 实战开发之缓存(Cache)
- TP5实战源码---应用缓存获取城市信息
- TP5实战源码---应用缓存获取分类详情
- 进阶篇六 TP5类库的封装和使用
- DataEdit快捷操作类库
- ShowCode快捷使用类库
- 阿里大于 短信API接口 TP5专用类库
- DatabaseUpgrade数据库对比及更新类库
- AuthWeb权限类使用说明
- 进阶篇七 服务层的应用
- 服务层源码示例
- 服务层基类源码
- 进阶篇八 应用层Redis数据处理基类
- Redis服务层基类源码
- 进阶篇九 使用Redis类库处理一般的抢购(秒杀)活动示例
- 进阶篇十 某大型项目应用本Redis类源码示例(含事务 乐观锁)
- 进阶篇十一 逻辑层的应用
- 逻辑层基类源码
- 进阶篇 服务层代码示例
- 高阶实战课程 进阶篇持续新增中
- 高阶篇一 TP5命令行之守护任务源码
- TP5实战源码 --- 命令行
- TP5实战源码 --- 通过shell建立PHP守护程序
- 高阶篇二 使用Redis队列发送微信模版消息
- 高阶篇二 之 Worker队列基类源码
- 高阶篇三 TP5实战之Redis缓存应用
- Redis实战源码之Hash专用类库源码
- Redis实战源码之Model类结合
- Redis实战源码之模型Hash基类源码
- Redis实战源码之Hash查询使用技巧
- Redis实战源码之 shell脚本中redis赋值和取值
- 高阶篇四 Swoole的实战应用
- swoole基类代码
- Swoole扩展WebsocketServer专用类
- 基于Swoole的多Room聊天室的程序
- Swoole守护服务shell源码
- 高阶篇五 命令行异步多进程队列类的应用
- tp_worker类源码
- WorkerBase
- WorkerCommand
- WorkerRedis
- Redis类
- CycleWorkBase
- WorkerHookBase异步钩子
- 队列日志SQL
- 高阶篇六 定时执行队列类库以及使用方法
- 定时队列类库源码
- 高阶篇七 异步执行循环队列类库以及使用教程
- CycleWorkBase源码
- 高阶实战课程 进阶篇持续新增中
- Extend便捷类库源码库
- 阿里相关类库
- SendSms--验证码API接口文件
- 权限相关类库目录
- AuthWeb 权限验证类库
- Redis便捷操作类库(20171224更新)
- Redis
- Tools工具类库集
- Curl类库
- DataEdit
- Rand类库
- ShowCode类库
- Upload类库
- 附件集合
- 附件一:微信支付 实战开发源码
- 微信支付类库源代码
- Common_util_pub.php
- DownloadBill_pub.php
- JsApi_pub.php
- NativeCall_pub.php
- NativeLink_pub.php
- OrderQuery_pub.php
- Refund_pub.php
- RefundQuery_pub.php
- SDKRuntimeException.php
- ShortUrl_pub.php
- UnifiedOrder_pub.php
- Wxpay_client_pub.php
- Wxpay_server_pub.php
- WxPayConf_pub.php
- 微信支付回调页面源码
- 附件二 顺丰快递BSP接口实战开发源码
- 顺丰快递BSP接口实战开发源码
- 顺丰BSP基类
- 顺丰BSP基础代码
- 顺丰BSP下单接口
- 顺丰BSP查单接口
- 顺丰BSP确认/取消接口
- 附件三 APP注册登陆接口源码(含融云平台接口)
- 附件四 TP5订单Model(含事务 获取器 修改器等方法)
- 附录五 RSA加密解密
- Rsa文件源码
- 附件六 阿里大于短信接口
- 附件七 AES加解密类
- AES加解密类源码
- 附件八 TP5路由设置源码
- 附件九 TP5 Excel导入导出下载便捷类库
- Excel类库TP5源码
- 附件十 TP5便捷操作Redis类库源码
- TP5源码 Redis操作便捷类库
- 附件十一 TP5源码 上传文件入库类源码
- 上传类Upload源码
- Upload类上传配置文件
- 存储图像文件的数据库SQL文件
- 存储文件的数据库SQL文件
- 附件十二 TP5 图片处理增强类 支持缩略图在线显示
- 附件十三 微信推送消息接口类库源码
- 附件十三 微信推送消息接口类库源码 之 基类
- 附件十四 存储微信昵称的处理方法