# 微信公眾號推送接口對接教程
[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 現在微信的接口已經搭建好了 剩余就是配置微信參數了
## **第二步 配置微信參數**
配置參數詳見
http://www.hmoore.net/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 圖片處理增強類 支持縮略圖在線顯示
- 附件十三 微信推送消息接口類庫源碼
- 附件十三 微信推送消息接口類庫源碼 之 基類
- 附件十四 存儲微信昵稱的處理方法