微信公衆平臺開發(83) 生成帶參數二維碼(轉)

本文介紹在微信公衆平臺上如何使用高級接口開發生成帶參數二維碼的功能。數據庫

 

1、場景二維碼

爲了知足用戶渠道推廣分析的須要,公衆平臺提供了生成帶參數二維碼的接口。使用該接口能夠得到多個帶不一樣場景值的二維碼,用戶掃描後,公衆號能夠接收到事件推送。api

目前有2種類型的二維碼,分別是臨時二維碼和永久二維碼,前者有過時時間,最大爲1800秒,但可以生成較多數量,後者無過時時間,數量較少(目前參數只支持1--100000)。兩種二維碼分別適用於賬號綁定、用戶來源統計等場景。瀏覽器

用戶掃描帶場景值二維碼時,可能推送如下兩種事件:微信

若是用戶還未關注公衆號,則用戶能夠關注公衆號,關注後微信會將帶場景值關注事件推送給開發者。微信公衆平臺

若是用戶已經關注公衆號,在用戶掃描後會自動進入會話,微信也會將帶場景值掃描事件推送給開發者。this

獲取帶參數的二維碼的過程包括兩步,首先建立二維碼ticket,而後憑藉ticket到指定URL換取二維碼。url

 

2、建立二維碼ticket

每次建立二維碼ticket須要提供一個開發者自行設定的參數(scene_id),分別介紹臨時二維碼和永久二維碼的建立二維碼ticket過程。spa

臨時二維碼請求說明3d

http請求URLcode

https://api.weixin.qq.com/cgi-bin/qrcode/create?access_token=TOKEN

POST數據格式

複製代碼
1 {
2     "expire_seconds": 1800,
3     "action_name": "QR_SCENE",
4     "action_info": {
5         "scene": {
6             "scene_id": 100000
7         }
8     }
9 }
複製代碼

返回格式:

{
    "ticket": "gQFK8DoAAAAAAAAAASxodHRwOi8vd2VpeGluLnFxLmNvbS9xL3kweXE0T3JscWY3UTltc3ZPMklvAAIEG9jUUgMECAcAAA==",
    "expire_seconds": 1800
}

永久二維碼請求說明

http請求URL

https://api.weixin.qq.com/cgi-bin/qrcode/create?access_token=TOKEN

POST數據格式

複製代碼
{
    "action_name": "QR_LIMIT_SCENE",
    "action_info": {
        "scene": {
            "scene_id": 1000
        }
    }
}
複製代碼

返回格式

{
    "ticket": "gQHi8DoAAAAAAAAAASxodHRwOi8vd2VpeGluLnFxLmNvbS9xL0UweTNxNi1sdlA3RklyRnNKbUFvAAIELdnUUgMEAAAAAA=="
}

提交數據參數說明:

返回結果參數說明

程序實現

 

3、經過ticket換取二維碼

獲取二維碼ticket後,開發者可用ticket換取二維碼圖片。無須登陸態便可調用。

HTTPS GET請求說明(TICKET必需UrlEncode)

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

ticket正確狀況下,http 返回碼是200,是一張圖片,能夠直接展現或者下載。

HTTP頭示例以下:

複製代碼
 1 {
 2     "url": "https://mp.weixin.qq.com/cgi-bin/showqrcode?ticket=gQHi8DoAAAAAAAAAASxodHRwOi8vd2VpeGluLnFxLmNvbS9xL0UweTNxNi1sdlA3RklyRnNKbUFvAAIELdnUUgMEAAAAAA%3D%3D",
 3     "content_type": "image/jpg",
 4     "http_code": 200,
 5     "header_size": 162,
 6     "request_size": 181,
 7     "filetime": -1,
 8     "ssl_verify_result": 20,
 9     "redirect_count": 0,
10     "total_time": 0.509,
11     "namelookup_time": 0,
12     "connect_time": 0.058,
13     "pretransfer_time": 0.343,
14     "size_upload": 0,
15     "size_download": 28497,
16     "speed_download": 55986,
17     "speed_upload": 0,
18     "download_content_length": 28497,
19     "upload_content_length": 0,
20     "starttransfer_time": 0.481,
21     "redirect_time": 0
22 }
複製代碼

下面是二種場景二維碼的URL及生成的圖片

https://mp.weixin.qq.com/cgi-bin/showqrcode?ticket=gQFK8DoAAAAAAAAAASxodHRwOi8vd2VpeGluLnFxLmNvbS9xL3kweXE0T3JscWY3UTltc3ZPMklvAAIEG9jUUgMECAcAAA%3d%3d

https://mp.weixin.qq.com/cgi-bin/showqrcode?ticket=gQHi8DoAAAAAAAAAASxodHRwOi8vd2VpeGluLnFxLmNvbS9xL0UweTNxNi1sdlA3RklyRnNKbUFvAAIELdnUUgMEAAAAAA%3d%3d

 

4、下載二維碼

二維碼生成之後,能夠在瀏覽器中右鍵另存爲本地圖片,但若是有不少二維碼的時候,用程序來下載就比較方便。

咱們使用CURL獲取圖片的全部信息,並將圖片數據保存爲一個文件。一個完整的下載代碼以下:

這樣,在程序當前目錄就會生成一個包含二維碼的圖片文件。

 

5、掃描帶參數二維碼事件

用戶掃描帶場景值二維碼時,可能推送如下兩種事件:

若是用戶還未關注公衆號,則用戶能夠關注公衆號,關注後微信會將帶場景值關注事件推送給開發者。

若是用戶已經關注公衆號,則微信會將帶場景值掃描事件推送給開發者。

1. 用戶未關注時,進行關注後的事件推送

複製代碼
<xml>
<ToUserName><![CDATA[gh_45072270791c]]></ToUserName>
<FromUserName><![CDATA[o7Lp5t6n59DeX3U0C7Kric9qEx-Q]]></FromUserName>
<CreateTime>1389684286</CreateTime>
<MsgType><![CDATA[event]]></MsgType>
<Event><![CDATA[subscribe]]></Event>
<EventKey><![CDATA[qrscene_1000]]></EventKey>
<Ticket><![CDATA[gQHi8DoAAAAAAAAAASxodHRwOi8vd2VpeGluLnFxLmNvbS9xL0UweTNxNi1sdlA3RklyRnNKbUFvAAIELdnUUgMEAAAAAA==]]></Ticket>
</xml>
複製代碼

參數說明

2. 用戶已關注時的事件推送

複製代碼
<xml>
<ToUserName><![CDATA[gh_45072270791c]]></ToUserName>
<FromUserName><![CDATA[o7Lp5t6n59DeX3U0C7Kric9qEx-Q]]></FromUserName>
<CreateTime>1389684184</CreateTime>
<MsgType><![CDATA[event]]></MsgType>
<Event><![CDATA[SCAN]]></Event>
<EventKey><![CDATA[1000]]></EventKey>
<Ticket><![CDATA[gQHi8DoAAAAAAAAAASxodHRwOi8vd2VpeGluLnFxLmNvbS9xL0UweTNxNi1sdlA3RklyRnNKbUFvAAIELdnUUgMEAAAAAA==]]></Ticket>
</xml>
複製代碼

參數說明

事件代碼:

如下代碼斷定了掃描帶參數二維碼的兩種情形

複製代碼
private function receiveEvent($object)
{
    $contentStr = "";
    switch ($object->Event)
    {
        case "subscribe":
            $contentStr = "歡迎關注方倍工做室 ";
            if (isset($object->EventKey)){
                $contentStr = "關注二維碼場景 ".$object->EventKey;
            }
            break;
        case "SCAN":
            $contentStr = "掃描 ".$object->EventKey;
             //要實現統計分析,則須要掃描事件寫入數據庫,這裏能夠記錄 EventKey及用戶OpenID,掃描時間
            break;
        default:
            break;      
 
    }
    $resultStr = $this->transmitText($object, $contentStr);
    return $resultStr;
}
複製代碼

 

6、渠道統計分析

後臺將得到全部二維碼關注狀況,數據以下所示:

對其進行簡單統計分析後,效果如圖

相關文章
相關標籤/搜索