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 中获得推送事件,在事件中有我们生成二维码的参数值,这样我们就可以知道用户具体扫描了哪一个二维码了,配合业务实现我们的具体需求。

相关推荐: