微信公眾平臺開發生成帶引數二維碼
為了滿足使用者渠道推廣分析的需要,公眾平臺提供了生成帶引數二維碼的介面。使用該介面可以獲得多個帶不同場景值的二維碼,使用者掃描後,公眾號可以接收到事件推送。
目前有2種類型的二維碼,分別是臨時二維碼和永久二維碼,前者有過期時間,最大為1800秒,但能夠生成較多數量,後者無過期時間,數量較少(目前引數只支援1--100000)。兩種二維碼分別適用於帳號繫結、使用者來源統計等場景。
使用者掃描帶場景值二維碼時,可能推送以下兩種事件:
如果使用者還未關注公眾號,則使用者可以關注公眾號,關注後微信會將帶場景值關注事件推送給開發者。
如果使用者已經關注公眾號,在使用者掃描後會自動進入會話,微信也會將帶場景值掃描事件推送給開發者。
獲取帶引數的二維碼的過程包括兩步,首先建立二維碼ticket,然後憑藉ticket到指定URL換取二維碼。
二、建立二維碼ticket
每次建立二維碼ticket需要提供一個開發者自行設定的引數(scene_id),分別介紹臨時二維碼和永久二維碼的建立二維碼ticket過程。
臨時二維碼請求說明
http請求URL
https://api.weixin.qq.com/cgi-bin/qrcode/create?access_token=TOKEN
POST資料格式
{
"expire_seconds": 1800,
"action_name": "QR_SCENE",
"action_info": {
"scene": {
"scene_id": 100000
}
}
}
返回格式:
{ "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==" }
提交資料引數說明:
返回結果引數說明
程式實現
三、通過ticket換取二維碼獲取二維碼ticket後,開發者可用ticket換取二維碼圖片。無須登入態即可呼叫。
HTTPS GET請求說明(TICKET必需UrlEncode)
https://mp.weixin.qq.com/cgi-bin/showqrcode?ticket=TICKET
ticket正確情況下,http 返回碼是200,是一張圖片,可以直接展示或者下載。
HTTP頭示例如下:
{ 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
四、下載二維碼
二維碼生成以後,可以在瀏覽器中右鍵另存為本地圖片,但如果有很多二維碼的時候,用程式來下載就比較方便。
我們使用CURL獲取圖片的所有資訊,並將圖片資料儲存為一個檔案。一個完整的下載程式碼如下:
這樣,在程式當前目錄就會生成一個包含二維碼的圖片檔案。
五、掃描帶引數二維碼事件
使用者掃描帶場景值二維碼時,可能推送以下兩種事件:
如果使用者還未關注公眾號,則使用者可以關注公眾號,關注後微信會將帶場景值關注事件推送給開發者。
如果使用者已經關注公眾號,則微信會將帶場景值掃描事件推送給開發者。
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; }六、渠道統計分析
後臺將獲得所有二維碼關注情況,資料如下所示:
對其進行簡單統計分析後,效果如圖