首頁 > php框架 > Laravel > 主體

小白教學:laravel結合easywechat發送公眾號範本訊息

藏色散人
發布: 2021-12-14 15:02:30
轉載
4145 人瀏覽過

最近接到新需求,需要給關注服務號的用戶發送模板訊息,寫個博客記錄一下完成此次需求走過的路,擴展包使用的是easywechat
laravel結合easywechat發送公眾號範本訊息詳細說明,感謝easywechat作者,對新手來說可太好用了!
因為我們情況比較特殊,小程式綁定的公眾號和要推送的公眾號不是同一個,這個就涉及到union_Id可能不一致的情況,因此需要將兩個公眾號都綁定到微信開放平台,如果沒有,就去註冊綁定
微信開放平台文檔

小白教學:laravel結合easywechat發送公眾號範本訊息

#因為我這邊是全新的公眾號,所以步驟會比較小白

配置js安全性網域

小白教學:laravel結合easywechat發送公眾號範本訊息

#產生secret(主要要保存好,後續重置會影響已上線的業務)

小白教學:laravel結合easywechat發送公眾號範本訊息

填寫並啟用伺服器設定

小白教學:laravel結合easywechat發送公眾號範本訊息
這裡填寫的伺服器位址會用於後續收到公眾號的各種事件回調,例如關注取消
本地調試需要做內網穿透,具體教程自己去搜吧我也不會

修改設定微信這邊會驗證填寫的伺服器位址是否能正常接收,所以會走一次驗證需要介面給予正確回傳參數
存取文件連結參考
因為微信的驗證和後續的回調都會走這一路由,驗證為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;
登入後複製

效果圖

小白教學:laravel結合easywechat發送公眾號範本訊息(未完成)

#微信公眾號的關注回呼事件會將用戶的基本訊息和unionid也一併發送,一定要將公眾號的openid和unionid存起來,後續發送模板訊息會根據公眾號的openid進行發送

在微信公眾平台申請開通模板訊息,在右側選單最下邊「 新功能」找到範​​本訊息,點選申請開通,大概需要1-3個工作天。我這邊是1天就通過了

小白教學:laravel結合easywechat發送公眾號範本訊息(未完成)

開通後,選擇行業,選擇模板類型,如果微信提供的模板庫找不到和你業務一樣的,那就需要自己去提交申請了,但是這個時間比較久,大概需要7-15天,建議還是用模板庫的

小白教學:laravel結合easywechat發送公眾號範本訊息(未完成)
這裡的模板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結合easywechat發送公眾號範本訊息的完整過程,完畢!

相關推薦:最新的五個Laravel影片教學
#

以上是小白教學:laravel結合easywechat發送公眾號範本訊息的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:learnku.com
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板