最近接到新需求,需要給關注服務號的用戶發送模板訊息,寫個博客記錄一下完成此次需求走過的路,擴展包使用的是easywechat
laravel結合easywechat發送公眾號範本訊息詳細說明,感謝easywechat作者,對新手來說可太好用了!
因為我們情況比較特殊,小程式綁定的公眾號和要推送的公眾號不是同一個,這個就涉及到union_Id可能不一致的情況,因此需要將兩個公眾號都綁定到微信開放平台,如果沒有,就去註冊綁定
微信開放平台文檔
配置js安全性網域
#產生secret(主要要保存好,後續重置會影響已上線的業務)
填寫並啟用伺服器設定
這裡填寫的伺服器位址會用於後續收到公眾號的各種事件回調,例如關注取消
本地調試需要做內網穿透,具體教程自己去搜吧我也不會
修改設定微信這邊會驗證填寫的伺服器位址是否能正常接收,所以會走一次驗證需要介面給予正確回傳參數
存取文件連結參考
因為微信的驗證和後續的回調都會走這一路由,驗證為GET請求,後續的事件回呼之類是post請求,因此需要將路由設為any類型Route::any('official/notify', 'WechatController@officialNotify');easywechat作者安正超老師為我們考慮了伺服器驗證 與訊息的接收與回覆在一個連結的相容,所以直接按照文件使用即可
public function officialNotify() { Log::channel('wechat')->info("公众号回调!!!!!1" ); $body = file_get_contents('php://input'); Log::channel('wechat')->info($body); $config = [ 'app_id' => config('wechat.yueliu_official_account.app_id'), 'secret' => config('wechat.yueliu_official_account.secret'), 'token' => config('wechat.yueliu_official_account.token'),// 'aes_key' => config('wechat.yueliu_official_account.aes_key'), // 明文模式请勿填写 EncodingAESKey 'aes_key' => '', // 明文模式请勿填写 EncodingAESKey 'log' => [ 'level' => 'error', 'file' => storage_path('logs/wechat.log'), ], 'response_type' => 'array' ]; $app = Factory::officialAccount($config); $app->server->push(function ($message) { Log::channel('wechat')->info($message); switch ($message['MsgType']) { case 'event': return '收到事件消息'; break; case 'text': return '收到文本消息'; break; case 'image': return '收到图片消息'; break; case 'voice': return '收到语音消息'; break; case 'video': return '收到视频消息'; break; case 'location': return '收到坐标消息'; break; case 'link': return '收到链接消息'; break; case 'file': return '收到文件消息'; // ... 其它消息 default: return '收到其它消息'; break; } }); // 在 laravel 中: $response = $app->server->serve(); // $response 为 `Symfony\Component\HttpFoundation\Response` 实例 // 对于需要直接输出响应的框架,或者原生 PHP 环境下 $response->send(); // 而 laravel 中直接返回即可: return $response; }
我這邊的業務需要,在使用者追蹤後需要發送可以跳轉小程式的訊息給用戶,這裡需要在收到event訊息後,判斷是否是追蹤事件,然後將return的訊息改為下面的程式碼即可,這裡的a連結點擊後可直接開啟小程式,不會在問用戶是否確認之類的提示
需要注意的是:關注公眾號通過[$app->user->get($openId);]可以拿到unionid和一些基本信息,取消關注只能拿到openid
case 'event': return '欢迎关注音视频资产管理与协同交付平台「laravel」官方微信。 <a>点击跳转</a> 网页版请至: https://learnku.com'; break;
效果圖
#微信公眾號的關注回呼事件會將用戶的基本訊息和unionid也一併發送,一定要將公眾號的openid和unionid存起來,後續發送模板訊息會根據公眾號的openid進行發送
在微信公眾平台申請開通模板訊息,在右側選單最下邊「 新功能」找到範本訊息,點選申請開通,大概需要1-3個工作天。我這邊是1天就通過了
開通後,選擇行業,選擇模板類型,如果微信提供的模板庫找不到和你業務一樣的,那就需要自己去提交申請了,但是這個時間比較久,大概需要7-15天,建議還是用模板庫的
這裡的模板id要存在程式碼裡,後續發送模板訊息需要用到
下面就是根據業務需要,給用戶發送模板訊息了,代碼如下
$openId = '公众号的openid'; $config = [ 'app_id' => config('wechat.yueliu_official_account.app_id'), 'secret' => config('wechat.yueliu_official_account.secret'), 'token' => config('wechat.yueliu_official_account.token'), // 'aes_key' => config('wechat.yueliu_official_account.aes_key'), // 明文模式请勿填写 EncodingAESKey 'aes_key' => '', // 明文模式请勿填写 EncodingAESKey 'log' => [ 'level' => 'error', 'file' => storage_path('logs/wechat.log'), ], 'response_type' => 'array' ]; $app = Factory::officialAccount($config);// $user = $app->user->get($openId);// dd($user); // 发送模板消息 $app->template_message->send([ 'touser' => $openId, 'template_id' => '模板id', 'url' => 'http://www.网站.cn', 'miniprogram' => [ // 跳转到小程序,和上面的url同时存在的话,则优先显示小程序 'appid' => '小程序的id', 'pagepath' => '小程序页面地址', ], 'data' => [ 'first' => [ 'value' => '赵师傅已加入群组演示项目', 'color' => '#888888' ], 'keyword1' => [ 'value' => '加入项目' ], 'keyword2' => [ 'value' => '加入成功' ], 'keyword3' => [ 'value' => '2021-12-10 14:21:05' ], 'remark' => [ 'value' => '点击打开小程序' ], ], ]);
效果圖
以上就是laravel結合easywechat發送公眾號範本訊息的完整過程,完畢!
相關推薦:最新的五個Laravel影片教學#
以上是小白教學:laravel結合easywechat發送公眾號範本訊息的詳細內容。更多資訊請關注PHP中文網其他相關文章!