Yii實現微信公眾號場景二維碼的方法實例
前言
在Yii中實現場景二維碼這里我使用的是easywechat插件,安裝easywechat插件
composer require jianyan74/yii2-easy-wechat
github地址: https://github.com/jianyan74/yii2-easy-wechat
easywechat文檔地址: https://www.easywechat.com/docs/master/overview
生成場景二維碼前提:
微信的場景二維碼功能主要是生成一個微信二維碼,然后在手機使用微信掃描此二維碼時,會觸發(fā)微信通知,所以我們在生成場景二維碼之前進行微信的服務端驗證
1:服務端驗證
$app = Yii::$app->wechat->getApp(); $server = $app->server; $response = $server->serve(); $response->send(); exit();
服務端驗證代碼完成之后在微信公眾號進行服務端驗證即可
2:生成場景二維碼
$app = Yii::$app->wechat->getApp();
$app->server->push(function ($message) use ($app) {
switch ($message['MsgType']){
case 'event':
//掃碼事件:SCAN 訂閱事件:subscribe
if (isset($message['Event']) && ($message['Event'] == 'SCAN' || $message['Event'] == 'subscribe')) {
$openId = $message['FromUserName'];//掃面用戶的openID
//獲取參數
if ($message['Event'] == 'SCAN') {
$code= $message['EventKey'];
} else {
$code= str_replace('qrscene_', '', $message['EventKey']);
}
//發(fā)送圖文消息
$items = [
new NewsItem([
'title'=> '圖文標題',
'description' => '圖文描述',
'url' => '圖文鏈接',
'image'=> '圖文圖片,
]),
];
return new News($items);
}
break;
default:
break;
}
});
$server = $app->server;
$response = $server->serve();
$response->send();
exit();
根據如上就可以實現場景二維碼
總結
到此這篇關于Yii實現微信公眾號場景二維碼的文章就介紹到這了,更多相關Yii實現微信公眾號場景二維碼內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
php 與 nginx 的處理方式及nginx與php-fpm通信的兩種方式
這篇文章主要介紹了php 與 nginx 的兩種處理方式及nginx與php-fpm通信的兩種方式,需要的朋友可以參考下2018-09-09
實現php加速的eAccelerator dll支持文件打包下載
實現php加速的eAccelerator dll支持文件打包下載...2007-09-09
laravel 解決Eloquent ORM的save方法無法插入數據的問題
今天小編就為大家分享一篇laravel 解決Eloquent ORM的save方法無法插入數據的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-10-10

