溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Force.com微信開(kāi)發(fā)如何生成帶參數(shù)的二維碼

發(fā)布時(shí)間:2021-09-06 15:52:52 來(lái)源:億速云 閱讀:107 作者:小新 欄目:移動(dòng)開(kāi)發(fā)

這篇文章給大家分享的是有關(guān)Force.com微信開(kāi)發(fā)如何生成帶參數(shù)的二維碼的內(nèi)容。小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,一起跟隨小編過(guò)來(lái)看看吧。

為了滿足用戶渠道推廣分析的需要,公眾平臺(tái)提供了生成帶二維碼的接口。使用該接口可以獲得多個(gè)帶不同場(chǎng)景值的二維碼,用戶掃描后,公眾號(hào)可以接收到事件推送。目前有兩種類型的二維碼,分別是臨時(shí)二維碼和永久二維碼,前者有過(guò)期時(shí)間,最大為1800秒,但能夠生成較多數(shù)量,后者無(wú)過(guò)期時(shí)間,數(shù)量較少(目前參數(shù)只支持1到100000)。兩種二維碼分別適用于賬號(hào)綁定、用戶來(lái)源統(tǒng)計(jì)等場(chǎng)景。

用戶掃描帶場(chǎng)景值二維碼時(shí),可能推送以下兩種事件:

1. 如果用戶還未關(guān)注公眾號(hào),則用戶可以關(guān)注公眾號(hào),關(guān)注后微信會(huì)將帶場(chǎng)景值關(guān)注事件推送給開(kāi)發(fā)者(例如為特定活動(dòng)準(zhǔn)備的二維碼,與會(huì)者掃描后關(guān)注微信賬號(hào),與此同時(shí)微信賬號(hào)可以將活動(dòng)相關(guān)的信息推送給用戶);

2. 如果用戶已經(jīng)關(guān)注公眾號(hào),在用戶掃描后會(huì)自動(dòng)進(jìn)入會(huì)話,微信也會(huì)將帶場(chǎng)景值掃描事件推送給開(kāi)發(fā)者(上例同樣適用)。

獲取帶參數(shù)的二維碼的過(guò)程包括兩步,首先創(chuàng)建二維碼ticket,然后憑借ticket到指定URL換取二維碼。

創(chuàng)建二維碼ticket

每次創(chuàng)建二維碼ticket需要提供一個(gè)開(kāi)發(fā)者自行設(shè)定的參數(shù)(scene_id),分別介紹臨時(shí)二維碼和永久二維碼的創(chuàng)建二維碼ticket過(guò)程。

臨時(shí)二維碼請(qǐng)求說(shuō)明:

 http請(qǐng)求方式: POST
 URL:  
 POST數(shù)據(jù)格式:json
 POST數(shù)據(jù)例子:{"expire_seconds": 1800, "action_name": "QR_SCENE", "action_info": {"scene": {"scene_id": 123}}}

永久二維碼請(qǐng)求說(shuō)明

 http請(qǐng)求方式: POST
 URL:  
 POST數(shù)據(jù)格式:json
 POST數(shù)據(jù)例子:{"action_name": "QR_LIMIT_SCENE", "action_info": {"scene": {"scene_id": 123}}}

請(qǐng)求JSON數(shù)據(jù)參數(shù)的具體說(shuō)明如下:

Force.com微信開(kāi)發(fā)如何生成帶參數(shù)的二維碼

正確的Json返回結(jié)果示例如下:

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

返回Json數(shù)據(jù)的格式說(shuō)明如下:

Force.com微信開(kāi)發(fā)如何生成帶參數(shù)的二維碼

錯(cuò)誤的Json返回示例如下:

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

下面我們構(gòu)造一個(gè)Visualforce Page來(lái)生成ticket。

Visualforce Page代碼如下:

<apex:page standardstylesheets="false" showHeader="false" sidebar="false" controller="WeChatQRCodeGeneratorController" > 
   <apex:form > 
      <font face="微軟雅黑"><strong>第一步,創(chuàng)建二維碼Ticket</strong><br /><br /> 
      請(qǐng)輸入授權(quán)AccessToken:<apex:inputText size="100" value="{!accessToken}" id="accessToken"/><br /><br /> 
      <apex:commandButton value="生成創(chuàng)建二維碼Ticket"  action="{!send}" id="send"  /><br /> 
      </font> 
  </apex:form> 
  {!msg} 
</apex:page>

上面代碼第4行放置了一個(gè)apex:inputText控件,相當(dāng)于HTML的文本框,value的值指定了accessToken,這個(gè)必須是WeChatQRCodeGeneratorController類里一個(gè)有Getter Setter的公開(kāi)屬性,如過(guò)該屬性有默認(rèn)值則文本框會(huì)顯示這個(gè)默認(rèn)值,如果用戶修改了文本框的內(nèi)容,accessToken屬性的值也會(huì)自動(dòng)改變。第5行放置了一個(gè)apex:commandButton控件,相當(dāng)于HTML的按鈕,點(diǎn)擊這個(gè)按鈕將觸發(fā)action處指定的方法send。最后第8行直接顯示msg變量,該變量會(huì)用來(lái)顯示微信接口返回的Json。畫(huà)面顯示效果如下:

Force.com微信開(kāi)發(fā)如何生成帶參數(shù)的二維碼

WeChatQRCodeGeneratorController類的代碼如下:

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('Accept-Encoding','gzip,deflate'); 
        req.setHeader('Content-Type','text/xml;charset=UTF-8'); 
        req.setHeader('User-Agent','Jakarta Commons-HttpClient/3.1'); 
        
        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,點(diǎn)擊“生成創(chuàng)建二維碼Ticket”按鈕將會(huì)得到如下圖所示的用來(lái)?yè)Q取二維碼的票據(jù)。其實(shí)返回的json里最后一個(gè)參數(shù)url的值即是二維碼的值,可以拿這個(gè)結(jié)果通過(guò)在線二維碼生成器生成二維碼:

Force.com微信開(kāi)發(fā)如何生成帶參數(shù)的二維碼

通過(guò)ticket換取二維碼

獲取二維碼ticket后,開(kāi)發(fā)者可用ticket換取二維碼圖片,本接口無(wú)需登錄即可調(diào)用,接口請(qǐng)求說(shuō)明如下:

 HTTP GET請(qǐng)求(請(qǐng)使用https協(xié)議)
 https://mp.weixin.qq.com/cgi-bin/showqrcode?ticket=TICKET
返回說(shuō)明:
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

錯(cuò)誤情況下(如ticket非法)返回HTTP錯(cuò)誤碼404。

利用前面返回的票據(jù)調(diào)用該接口示例如下:

https://mp.weixin.qq.com/cgi-bin/showqrcode?ticket=gQH97zoAAAAAAAAAASxodHRwOi8vd2VpeGluLnFxLmNvbS9xL2YweHpqY1hrX255RGdnckl0V0otAAIENIwAVAMECAcAAA==

感謝各位的閱讀!關(guān)于“Force.com微信開(kāi)發(fā)如何生成帶參數(shù)的二維碼”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,讓大家可以學(xué)到更多知識(shí),如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI