小编给大家分享一下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
生成场景二维码前提:
微信的场景二维码功能主要是生成一个微信二维码,然后在手机使用微信扫描此二维码时,会触发微信通知,所以我们在生成场景二维码之前进行微信的服务端验证
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']); } //发送图文消息 $items = [ new NewsItem([ 'title'=> '图文标题', 'description' => '图文描述', 'url' => '图文链接', 'image'=> '图文图片, ]), ]; return new News($items); } break; default: break; } }); $server = $app->server; $response = $server->serve(); $response->send(); exit();
根据如上就可以实现场景二维码
看完了这篇文章,相信你对“Yii如何实现微信公众号场景二维码”有了一定的了解,如果想了解更多相关知识,欢迎关注亿速云行业资讯频道,感谢各位的阅读!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。