网站设计
来源:028微信开发 | 2017-03-07
微信二维码是腾讯开发出的配合微信使用的添加好友和实现微信支付功能的一种新方式,是含有特定内容格式的,只能被微信软件正确解读的二维码。在当前可谓是相当的流行,不管是添加好友还是购物支付,扫一扫二维码就能快速解决问题。而微信官方为了满足用户渠道推广分析的需要,也为公众平台提供了生成带参数二维码的接口。微信开发者在使用该接口后即可获得多个带有不同场景值的二维码,用户扫描后,公众号可以接收到事件推送。那么,具体应该如何生成带参数的二维码呢?
首先,我们应该知道目前二维码的类型,分别临时二维码和永久二维码两者。前者有过期时间,最大为1800秒,但能够生成较多数量;而后者无过期时间,但数量较少(目前参数只支持1--100000)。两种二维码分别适用于帐号绑定、用户来源统计等场景。
当微信用户扫描带场景值的二维码时,可能推送以下两种事件:
如果用户还未关注公众号,则用户可以关注公众号,关注后微信会将带场景值关注事件推送给开发者;
如果用户已经关注公众号,在用户扫描后会自动进入会话,微信也会将带场景值扫描事件推送给开发者。
那么在开发过程中如何获取带有参数的二维码?首先,要创建二维码ticket,然后再凭借ticket链接到指定的URL换取二维码。
1 ticket的创建
每次创建二维码ticket需要提供一个开发者自行设定的参数(scene_id)。
1.1 请求说明
1.1.1 临时二维码请求说明
http请求方式: POST
URL: https://api.weixin.qq.com/cgi-bin/qrcode/create?access_token=TOKEN
POST数据格式:json
POST数据例子:{"expire_seconds": 1800, "action_name": "QR_SCENE", "action_info": {"scene": {"scene_id": 123}}}
1.1.2 永久二维码请求说明
http请求方式: POST
URL: https://api.weixin.qq.com/cgi-bin/qrcode/create?access_token=TOKEN
POST数据格式:json
POST数据例子:{"action_name": "QR_LIMIT_SCENE", "action_info": {"scene": {"scene_id": 123}}}
参数说明
1.2 返回说明
1.2.1 正确的Json返回结果:
{"ticket":"gQG28DoAAAAAAAAAASxodHRwOi8vd2VpeGluLnFxLmNvbS9xL0FuWC1DNmZuVEhvMVp4NDNMRnNRAAIEesLvUQMECAcAAA==","expire_seconds":1800}
1.2.2 错误的Json返回示例:
{"errcode":40013,"errmsg":"invalid appid"}
参数说明
2 换取二维码
获取二维码ticket后,开发者可用ticket换取二维码图片。请注意,本接口无须登录态即可调用。
2.1 请求说明
HTTP GET请求(请使用https协议)
https://mp.weixin.qq.com/cgi-bin/showqrcode?ticket=TICKET
提醒:TICKET记得进行UrlEncode
2.2 返回说明
2.2.1 正确的返回结果
ticket正确情况下,http返回码是200,是一张图片,可以直接展示或者下载。
HTTP头(示例)如下:
Accept-Ranges:bytes
Cache-control:max-age=604800
Connection:keep-alive
Content-Length:28026
Content-Type:image/jpg
Date:Wed, 16 Oct 2013 06:37:10 GMT
Expires:Wed, 23 Oct 2013 14:37:10 +0800
Server:nginx/1.4.1
2.2.2 错误的返回结果
错误情况下,如ticket非法,则返回HTTP错误码404。
当然,还有其他一些带参数二维码的生成方法,例如用带参数二维码生成器生成二维码也是相当简单、便捷的方法。不过对于微信开发爱好者来说,自己动手开发远比借助外在工具来得快活得多!