微信公眾號(hào)平臺(tái)接口開發(fā) 獲取access_token過(guò)程解析
新建Asp.net MVC 4.0項(xiàng)目
WeChatSubscript是項(xiàng)目UI層
WeChatTools是封裝操作訪問(wèn)公眾號(hào)接口的一些方法類庫(kù)
獲取AccssToken
我們要的得到AccessToken,這是所有接口訪問(wèn)的基礎(chǔ),我們看看官方給出的接口調(diào)用文檔
很簡(jiǎn)單明了,grant_type=client_credential,這是固定的不會(huì)變
appid與secret就是前面一章我叫大家記起來(lái)的那個(gè)認(rèn)證口令數(shù)據(jù)。
下邊我們來(lái)實(shí)現(xiàn)這個(gè)功能,新建WeCharBase.cs
public class WeCharBase { private static readonly string appId; private static readonly string appSecret; static WeCharBase() { appId = "**********"; appSecret = "832090bfddabbac19cc8da5053aea47b"; } public static string AccessToken { get { return GetAccessToken(); } } /// <summary>獲取access_token</summary> /// <param name="appId"></param> /// <param name="appSecret"></param> /// <returns></returns> private static string GetAccessToken() { if (HttpContext.Current == null) { return GetToken(); } var accessTokenCache = HttpContext.Current.Cache["access_token"]; if (accessTokenCache != null) { return accessTokenCache.ToString(); } else { return GetToken(); } } /// <summary>獲取ccess_token</summary> /// <returns></returns> private static string GetToken() { try { var client = new WebClient(); client.Encoding = Encoding.UTF8; var responseData = client.DownloadString(string.Format("https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid={0}&secret={1}", appId, appSecret)); var javaScriptSerializer = new JavaScriptSerializer(); var accessDictionary = javaScriptSerializer.Deserialize<Dictionary<string, object>>(responseData); var accessToken = accessDictionary["access_token"]; if (accessToken == null) { return string.Empty; } HttpContext.Current.Cache.Insert("access_token", accessToken, null, DateTime.Now.AddSeconds(7100), TimeSpan.Zero, CacheItemPriority.Normal, null); HttpContext.Current.Cache.Remove("ticket"); GetTicket(); return accessToken.ToString(); } catch (Exception ex) { return ex.Message; } } }
細(xì)心的童鞋功能注意到這里用了HttpContext.Current.Cache,為什么呢?
因?yàn)閍ccess_token在官方服務(wù)器會(huì)緩存2個(gè)小時(shí),請(qǐng)求一次,這個(gè)access_token在2個(gè)小時(shí)內(nèi)都有效
所以請(qǐng)求一次得到access_token后,在以后的2個(gè)小時(shí)內(nèi)都可以用這個(gè)access_token去訪問(wèn)其他接口
所以沒(méi)有必要每次請(qǐng)求不同的接口都請(qǐng)求access_token一次
UI層實(shí)現(xiàn)
我們新建控制器SubscriptController.cs
新增2個(gè)Action,ViewAccessToken
/// <summary>獲取AccessToken</summary> /// <returns></returns> public ActionResult ViewAccessToken() { return View(); } /// <summary>獲取AccessToken</summary> /// <returns></returns> public ActionResult GetAccessToken() { return Content(WeCharBase.AccessToken); }
新增視圖
<script type="text/javascript" language="javascript"> $(document).ready(function () { $("#btnGetAccessToken").click(function () { $.ajax({ type: "Get", url: "/Subscript/GetAccessToken", success: function (responseTest) { $("#txtAccessToken").text(responseTest); } }); }); }); </script> <table> <tr> <td> <div class="title">獲取access token</div> <textarea id="txtAccessToken" name="txtAccessToken" rows="4" style="width:500px"></textarea> </td> <td><input class="btncss" id="btnGetAccessToken" type="button" value=" 獲取 " /></td> </tr> </table>
運(yùn)行項(xiàng)目,看看效果
成功了,是不是很簡(jiǎn)單呀
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
JavaScript 經(jīng)典實(shí)例日常收集整理(常用經(jīng)典)
本文是小編日常收集整理些js經(jīng)典實(shí)例,非常具有參考借鑒價(jià)值,需要的朋友一起了解了解吧2016-03-03js實(shí)現(xiàn)鍵盤控制DIV移動(dòng)的方法
這篇文章主要介紹了js實(shí)現(xiàn)鍵盤控制DIV移動(dòng)的方法,以實(shí)例形式完整的講述了js控制div移動(dòng)所涉及的css、js與html使用技巧,需要的朋友可以參考下2015-01-01判斷目標(biāo)是否是window,document,和擁有tagName的Element的代碼
判斷目標(biāo)是否是window,document,和擁有tagName的Element的代碼,需要的朋友可以參考下。2010-05-05layui 對(duì)彈窗 form表單賦值的實(shí)現(xiàn)方法
今天小編就為大家分享一篇layui 對(duì)彈窗 form表單賦值的實(shí)現(xiàn)方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-09-09JS實(shí)現(xiàn)的冒泡排序,快速排序,插入排序算法示例
這篇文章主要介紹了JS實(shí)現(xiàn)的冒泡排序,快速排序,插入排序算法,結(jié)合實(shí)例形式分析了javascript冒泡排序,快速排序,插入排序算法的相關(guān)原理及實(shí)現(xiàn)方法,需要的朋友可以參考下2019-03-03