Salesforce Force.com Site 集成微信公众平台 (九) 生成二维码
为了满足市场用户推广的渠道,公众平台提供了生成带二维码的接口。使用该接口可以获得多个带不同场景值的二维码,用户扫描后,公众号可以接收到事件推送。目前有两种类型的二维码,分别是临时二维码和永久二维码,前者有过期时间,最大为30天(即2592000秒)后过期,但能够生成较多数量,后者无过期时间,数量较少(目前为最多10万个)。两种二维码分别适用于账号绑定、用户来源统计等场景。
扫描二维码推送事件
用户扫描带场景值二维码时,可以推送两种事件:
- 如果用户还未关注公众号,则用户可以关注公众号,关注后微信会将带场景值关注事件推送给开发者,例如为特定活动准备的二维码,与会者扫描后关注微信账号,与此同时微信账号可以将活动相关的信息推送给用户。
- 如果用户已经关注公众号,在用户扫描后会自动进入会话,微信也会将带场景值扫描事件推送给开发者。
创建带参数二维码
获取带参数二维码的过程包括两步,首先创建二维码 ticket, 然后凭借 ticket 到指定 URL 换取二维码。
创建二维码 ticket
每次创建二维码 ticket 需要提供一个开发者自行设定的参数 (scene_id),分别介绍临时二维码和永久二维码的创建过程。
临时二维码请求说明:
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}}}
永久二维码请求说明:
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}}}
或者也可以使用以下 POST 数据创建字符串形式的二维码参数:
{"action_name": "QR_LIMIT_STR_SCENE", "action_info": {"scene": {"scene_str": "123"}}}
请求 JSON 数据参数的具体说明如下:
正确的 JSON 返回结果示例如下:
{
"ticket":"gQEl8DoAAAAAAAAAASxodHRwOi8vd2VpeGluLnFxLmNvbS9xL0xEanloS3pseG1tLVl2ck9SQmJKAAIE2aIsVwMECAcAAA==",
"expire_seconds":1800,
"url":"http:\/\/weixin.qq.com\/q\/LDjyhKzlxmm-YvrORBbJ"
}
返回 JSON 数据的格式说明如下:
错误的 JSON 返回示例如下:
{"errcode":40013, "errmsg":"invalid appid"}
接下来我们创建一个 Visualforce Page 来生成 ticket。
Visualforce Page 代码如下
<apex:page standardstylesheets="false" showHeader="false" sidebar="false" controller="WeChatQRCodeGeneratorController" >
<apex:form >
请输入AccessToken:<apex:inputText size="100" value="{!accessToken}" id="accessToken"/><br /><br />
<apex:commandButton value="生成创建二维码Ticket" action="{!send}" id="send" /><br />
</apex:form>
{!msg}
</apex:page>
在页面上显示:
Apex Class 代码如下:
public class WeChatQRCodeGeneratorController
{
public String Msg { get; set; }
public String AccessToken { get; set; }
public void send()
{
Http h = new Http();
HttpRequest req = new HttpRequest();
req.setMethod('POST');
req.setHeader('Content-Type','text/xml');
String json = '{"expire_seconds": 1800, "action_name": "QR_SCENE", "action_info": {"scene": {"scene_id": 12345}}}';
req.setBody(json);
req.setEndpoint('https://api.weixin.qq.com/cgi-bin/qrcode/create?access_token=' + accessToken);
String bodyRes = '';
try
{
HttpResponse res = h.send(req);
bodyRes = res.getBody();
}
catch(System.CalloutException e)
{
System.debug('Callout error: '+ e);
ApexPages.addMessage(new ApexPages.Message(ApexPages.Severity.FATAL, e.getMessage()));
}
Msg = bodyRes;
}
}
代码完成后,在页面上输入有效的 Access Token, 点击 生成创建二维码 Ticket 按钮将会得到二维码的票据。其实返回的 json 里最后一个参数 url 的值即是二维码的值,可以拿这个结果通过在线二维码生成器生成二维码:
通过 ticket 换取二维码
获取二维码 ticket 后,开发者可以用 ticket 换取二维码图片,此接口无需登录即可调用,接口请求说明如下:
HTTP GET请求(请使用 https 协议)
https://mp.weixin.qq.com/cgi-bin/showqrcode?ticket=TICKET
利用前面返回的票据调用该接口示例:
https://mp.weixin.qq.com/cgi-bin/showqrcode?ticket=gQEl8DoAAAAAAAAAASxodHRwOi8vd2VpeGluLnFxLmNvbS9xL0xEanloS3pseG1tLVl2ck9SQmJKAAIE2aIsVwMECAcAAA==
直接在浏览器访问该接口将返回如下图所示的二维码图片,扫描该二维码图片将直接关注该公众账号:
同时 Salesforce 中获得推送事件,在事件中有我们生成二维码的参数值,这样我们就可以知道用户具体扫描了哪一个二维码了,配合业务实现我们的具体需求。