前言
在Yii中實現(xiàn)場景二維碼這里我使用的是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ā)微信通知,所以我們在生成場景二維碼之前進(jìn)行微信的服務(wù)端驗證
1:服務(wù)端驗證
$app = Yii::$app->wechat->getApp();
$server = $app->server;
$response = $server->serve();
$response->send();
exit();
服務(wù)端驗證代碼完成之后在微信公眾號進(jìn)行服務(wù)端驗證即可
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
//獲取參數(shù)
if ($message['Event'] == 'SCAN') {
$code= $message['EventKey'];
} else {
$code= str_replace('qrscene_', '', $message['EventKey']);
}
//發(fā)送圖文消息
$items = [
new NewsItem([
'title'=> '圖文標(biāo)題',
'description' => '圖文描述',
'url' => '圖文鏈接',
'image'=> '圖文圖片,
]),
];
return new News($items);
}
break;
default:
break;
}
});
$server = $app->server;
$response = $server->serve();
$response->send();
exit();
根據(jù)如上就可以實現(xiàn)場景二維碼
總結(jié)
到此這篇關(guān)于Yii實現(xiàn)微信公眾號場景二維碼的文章就介紹到這了,更多相關(guān)Yii實現(xiàn)微信公眾號場景二維碼內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!