微信 开发生成带参数的二维码的实例


Posted in PHP onNovember 23, 2016

微信开发生成带参数的二维码的讲解

在微信公众号平台开发者那里,在“账号管理”那里,有一项功能是“生成带参数的二维码”,通过这儿生成的二维码,只要通过微信扫一扫之后,会把事件自动推送到微信公众号上

用微信扫一扫推送到开发者网址那儿的数据如下:

<xml><ToUserName><![CDATA[gh_452****b0f2]]></ToUserName>
<FromUserName><![CDATA[oz1fVs4d****7FmFrCbc57o]]></FromUserName>
<CreateTime>1429416610</CreateTime>
<MsgType><![CDATA[event]]></MsgType>
<Event><![CDATA[SCAN]]></Event>
<EventKey><![CDATA[155120hzw]]></EventKey>
<Ticket><![CDATA[gQH17zoAAAAAAAAAASxodHR****S9xL28waUNrM1BsV1ZJZ0VJcE8tbUFMAAIEcCozVQMEAAAAAA==]]></Ticket>
</xml>

可以看出是一个xmlstk格式的数据,Event里SCAN表示扫描,EventKey是生成二维码时在json设置的数值,EventKey是可以自己指定的,其它都是微信平台内定的。。。通过自定义EventKey的数据,可以做到自动回复指定的数据

比如:我要做一个猜谜的游戏,每个猜谜都有一个唯一的编号,这个编号可以设置为EventKey值,然后别人扫描带参数的二维码时,会把谜语的编号(EventKey)传递过来,然后根据编号自动回复谜底给用户。。。。即做拿出微信扫一扫就知道谜底。

更多的应用场景请自由发挥,比如:扫一扫,领取红包等功能也是可以实现的。

微信官方开发文档:

为了满足用户渠道推广分析的需要,公众平台提供了生成带参数二维码的接口。使用该接口可以获得多个带不同场景值的二维码,用户扫描后,公众号可以接收到事件推送。 

目前有2种类型的二维码,分别是临时二维码和永久二维码,前者有过期时间,最大为1800秒,但能够生成较多数量,后者无过期时间,数量较少(目前参数只支持1--100000)。两种二维码分别适用于帐号绑定、用户来源统计等场景。

 用户扫描带场景值二维码时,可能推送以下两种事件: 

如果用户还未关注公众号,则用户可以关注公众号,关注后微信会将带场景值关注事件推送给开发者。
如果用户已经关注公众号,在用户扫描后会自动进入会话,微信也会将带场景值扫描事件推送给开发者。
获取带参数的二维码的过程包括两步,首先创建二维码ticket,然后凭借ticket到指定URL换取二维码。

ticket 单词的意思我查了一下百度字典,表示“票、入场券”的意思,即通过入场券来换取二维码。

换取的时候,其实就是把ticket加到URL的最后面,即xxxx.com/xxx.php?ticket=xxxx的形式

真实的效果如下:

其中ticket=xxx  后面的就是获取到的ticket数值。

微信官方文档如下:

每次创建二维码ticket需要提供一个开发者自行设定的参数(scene_id),分别介绍临时二维码和永久二维码的创建二维码ticket过程。

scene_id最大值是10万,请求的方式为post,被请求的网址都是一样的。

POST数据格式:json
POST数据例子:{"expire_seconds": 1800, "action_name": "QR_SCENE", "action_info": {"scene": {"scene_id": 123}}}

expire_seconds表示过期的秒数,如果含有这个参数,表示临时的二维码,即长3分钟后过期。

永久二维码的请求示例:

POST数据格式:json
POST数据例子:{"action_name": "QR_LIMIT_SCENE", "action_info": {"scene": {"scene_id": 123}}}
或者也可以使用以下POST数据创建字符串形式的二维码参数:
{"action_name": "QR_LIMIT_STR_SCENE", "action_info": {"scene": {"scene_str": "123"}}}

这里要注意一下,scene_str表求字符串,即推送的数据中EventKey的值是字符串,字符串要加双引号,可以发送英文字符。

如果scene_id永久二维码最大值是10万,只能是数字,不要加双引号

还有请求是post,数据格式为json

参数说明

参数 说明
expire_seconds 该二维码有效时间,以秒为单位。 最大不超过1800。
action_name 二维码类型,QR_SCENE为临时,QR_LIMIT_SCENE为永久,QR_LIMIT_STR_SCENE为永久的字符串参数值
action_info 二维码详细信息
scene_id 场景值ID,临时二维码时为32位非0整型,永久二维码时最大值为100000(目前参数只支持1--100000)
scene_str 场景值ID(字符串形式的ID),字符串类型,长度限制为1到64,仅永久二维码支持此字段

返回说明

正确的Json返回结果:

{"ticket":"gQH47joAAAAAAAAAASxodHRwOi8vd2VpeGluLnFxLmNvbS9xL2taZ2Z3TVRtNzJXV1Brb3ZhYmJJAAIEZ23sUwMEmm3sUw==","expire_seconds":60,"url":"http:\/\/weixin.qq.com\/q\/kZgfwMTm72WWPkovabbI"}

参数 说明
ticket 获取的二维码ticket,凭借此ticket可以在有效时间内换取二维码。
expire_seconds 二维码的有效时间,以秒为单位。最大不超过1800。
url 二维码图片解析后的地址,开发者可根据该地址自行生成需要的二维码图片

错误的Json返回示例:

{"errcode":40013,"errmsg":"invalid appid"}

通过ticket换取二维码

获取二维码ticket后,开发者可用ticket换取二维码图片。请注意,本接口无须登录态即可调用。

提醒:TICKET记得进行UrlEncode

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

PHP 相关文章推荐
PHP的类 功能齐全的发送邮件类
Oct 09 PHP
php win下Socket方式发邮件类
Aug 21 PHP
xml在joomla表单中的应用详解分享
Jul 19 PHP
CI框架中libraries,helpers,hooks文件夹详细说明
Jun 10 PHP
PHP实现简单ajax Loading加载功能示例
Dec 28 PHP
php实现评论回复删除功能
May 23 PHP
PHP 多任务秒级定时器的实现方法
May 13 PHP
ThinkPHP5框架实现简单的批量查询功能示例
Jun 07 PHP
php实现的表单验证类完整示例
Aug 13 PHP
PHP中类与对象功能、用法实例解读
Mar 27 PHP
PHP强制转化的形式整理
May 22 PHP
PHP类的自动加载与命名空间用法实例分析
Jun 05 PHP
微信 getAccessToken方法详解及实例
Nov 23 #PHP
Yii核心验证器api详解
Nov 23 #PHP
[原创]php集成安装包wampserver修改密码后phpmyadmin无法登陆的解决方法
Nov 23 #PHP
php in_array() 检查数组中是否存在某个值详解
Nov 23 #PHP
php 数组处理函数extract详解及实例代码
Nov 23 #PHP
CI框架封装的常用图像处理方法(缩略图,水印,旋转,上传等)
Nov 22 #PHP
php each 返回数组中当前的键值对并将数组指针向前移动一步实例
Nov 22 #PHP
You might like
jquery ajax执行后台方法
2010/03/18 Javascript
用JavaScript修改CSS属性的代码
2013/05/06 Javascript
JQueryiframe页面操作父页面中的元素与方法(实例讲解)
2013/11/19 Javascript
一个不错的仿携程自定义数据下拉选择select
2014/09/01 Javascript
JS实现带有3D立体感的银灰色竖排折叠菜单代码
2015/10/20 Javascript
JavaScript html5 canvas绘制时钟效果
2016/03/01 Javascript
AngularJS上拉加载问题解决方法
2016/05/23 Javascript
jQuery Easyui Datagrid实现单行的上移下移及保存移动的结果
2016/08/15 Javascript
jQuery Jsonp跨域模拟搜索引擎
2017/06/17 jQuery
Angular使用 ng-img-max 调整浏览器中的图片的示例代码
2017/08/17 Javascript
原生JavaScript实现remove()和recover()功能示例
2018/07/24 Javascript
Vue.js中该如何自己维护路由跳转记录
2019/05/19 Javascript
原生js实现each方法实例代码详解
2019/05/27 Javascript
使用Vue实现调用接口加载页面初始数据
2019/10/28 Javascript
微信小程序仿抖音视频之整屏上下切换功能的实现代码
2020/05/24 Javascript
Vue项目中数据的深度监听或对象属性的监听实例
2020/07/17 Javascript
JavaScript常用工具函数库汇总
2020/09/17 Javascript
Python splitlines使用技巧
2008/09/06 Python
python查看模块安装位置的方法
2018/10/16 Python
Pycharm无法显示动态图片的解决方法
2018/10/28 Python
Python requests设置代理的方法步骤
2020/02/23 Python
html5 自定义播放器核心代码
2013/12/20 HTML / CSS
mui几种页面跳转方式对比总结概括
2017/08/18 HTML / CSS
美国高端婴童品牌:Hanna Andersson
2016/10/30 全球购物
Ever New美国:澳大利亚领先的女装时尚品牌
2019/11/28 全球购物
以思科路由器为例你写下单臂路由的配置命令
2013/08/03 面试题
体育教育个人自荐信范文
2013/12/01 职场文书
化学系大学生自荐信范文
2014/03/01 职场文书
租房协议书范本
2014/04/09 职场文书
公司员工体检通知
2015/04/21 职场文书
2015年勤工助学工作总结
2015/04/29 职场文书
2015年为民办实事工作总结
2015/05/26 职场文书
2016年春季运动会广播稿
2015/08/19 职场文书
nginx简单配置多个server的方法
2021/03/31 Servers
分享mysql的current_timestamp小坑及解决
2021/11/27 MySQL
Ruby GDBM操作简介及数据存储原理
2022/04/19 Ruby