在進行推廣時,咱們能夠告訴對方,咱們的微信公衆帳號是什麼,客戶能夠去搜索,而後關注。二維碼給咱們提供了極大的便捷,只要簡單一掃描,便可關注。php
若是已經關注過,馬上跳入對話畫面。在咱們進行推廣時,再也不是簡陋的文字,能夠是一個有個性的二維碼,想必會很生動。nginx
微信對二維碼提供了很好的支持,並且還能夠根據須要生成不一樣場景的二維碼。下面咱們將介紹如何獲取和使用二維碼。 json
注意:限服務號,且進行了微信認證,費用300api
爲了知足用戶渠道推廣分析的須要,公衆平臺提供了生成帶參數二維碼的接口。使用該接口能夠得到多個帶不一樣場景值的二維碼,用戶掃描後,公衆號能夠接收到事件推送。微信
目前有2種類型的二維碼,分別是臨時二維碼和永久二維碼,前者有過時時間,最大爲1800秒,但可以生成較多數量,後者無過時時間,數量較少(目前參數只支持1--1000)。兩種二維碼分別適用於賬號綁定、用戶來源統計等場景。app
用戶掃描帶場景值二維碼時,可能推送如下兩種事件:微信公衆平臺
獲取帶參數的二維碼的過程包括兩步,首先建立二維碼ticket,而後憑藉ticket到指定URL換取二維碼。工具
每次建立二維碼ticket須要提供一個開發者自行設定的參數(scene_id),分別介紹臨時二維碼和永久二維碼的建立二維碼ticket過程。spa
臨時二維碼請求說明debug
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}}}
參數說明
參數 | 說明 |
---|---|
expire_seconds | 該二維碼有效時間,以秒爲單位。 最大不超過1800。 |
action_name | 二維碼類型,QR_SCENE爲臨時,QR_LIMIT_SCENE爲永久 |
action_info | 二維碼詳細信息 |
scene_id | 場景值ID,臨時二維碼時爲32位整型,永久二維碼時最大值爲1000 |
返回說明
正確的Json返回結果:
{"ticket":"gQG28DoAAAAAAAAAASxodHRwOi8vd2VpeGluLnFxLmNvbS9xL0FuWC1DNmZuVEhvMVp4NDNMRnNRAAIEesLvUQMECAcAAA==","expire_seconds":1800}
參數 | 說明 |
---|---|
ticket | 獲取的二維碼ticket,憑藉此ticket能夠在有效時間內換取二維碼。 |
expire_seconds | 二維碼的有效時間,以秒爲單位。最大不超過1800。 |
錯誤的Json返回示例:
{"errcode":40013,"errmsg":"invalid appid"}
獲取二維碼ticket後,開發者可用ticket換取二維碼圖片。請注意,本接口無須登陸態便可調用。
請求說明
HTTP GET請求(請使用https協議) https://mp.weixin.qq.com/cgi-bin/showqrcode?ticket=TICKET
返回說明
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
錯誤狀況下(如ticket非法)返回HTTP錯誤碼404。
依然基於以前的機器人案例進行功能添加,直接看代碼。
/// <summary> /// 二維碼管理者 /// </summary> public class DimensionalCodeManager { /// <summary> /// 臨時二維碼地址 /// </summary> /// 使用string.format時,報:字符串格式錯誤,由於其中有{ //private const string TEMP_URL = "{\"expire_seconds\": 1800, \"action_name\": \"QR_SCENE\", \"action_info\": {\"scene\": {\"scene_id\": {0}}}}"; /// <summary> /// 解決辦法,將原有字符串中的一個{用兩個{代替 /// </summary> private const string TEMP_JSON_DATA = "{{\"expire_seconds\": 1800, \"action_name\": \"QR_SCENE\", \"action_info\": {{\"scene\": {{\"scene_id\": {0}}}}}}}"; /// <summary> /// 永久二維碼地址 /// </summary> private const string PERMANENT_URL = "{{\"action_name\": \"QR_LIMIT_SCENE\", \"action_info\": {{\"scene\": {{\"scene_id\": {0}}}}}}}"; /// <summary> /// 獲取ticket的URL /// </summary> private const string GET_TICKET_URL = " https://api.weixin.qq.com/cgi-bin/qrcode/create?access_token={0}"; /// <summary> /// 獲取二維碼URL /// </summary> private const string GET_CODE_URL = "https://mp.weixin.qq.com/cgi-bin/showqrcode?ticket={0}"; /// <summary> /// 根據場景ID獲取ticket /// </summary> /// <param name="sceneID">場景ID</param> /// <param name="isTemp">是不是臨時二維碼</param> /// <returns></returns> private static string GetTicket(int sceneID, bool isTemp) { string result = null; string data = string.Empty; if (isTemp) { data = string.Format(TEMP_JSON_DATA, sceneID.ToString()); } else { if (sceneID > 0 && sceneID <= 1000) { data = string.Format(PERMANENT_URL, sceneID); } else { //scene_id不合法 return null; } } string ticketJson = HttpUtility.GetData(string.Format(GET_TICKET_URL,Context.AccessToken)); XDocument doc = XmlUtility.ParseJson(ticketJson, "root"); XElement root = doc.Root; if (root != null) { XElement ticket = root.Element("ticket"); if (ticket != null) { result = ticket.Value; } } return result; } /// <summary> /// 建立臨時二維碼 /// </summary> /// <param name="sceneID">場景id,int類型</param> /// <returns></returns> public static string GenerateTemp(int sceneID) { string ticket = GetTicket(sceneID,true); if (ticket == null) { return null; } return HttpUtility.GetData(string.Format(GET_CODE_URL, ticket)); } /// <summary> /// 建立臨時二維碼 /// </summary> /// <param name="sceneID">場景id,int類型</param> /// <returns></returns> public static string GeneratePermanent(int sceneID) { string ticket = GetTicket(sceneID, false); if (ticket == null) { return null; } return HttpUtility.GetData(string.Format(GET_CODE_URL, ticket)); } }