C#微信"平台開辟之access_token的獲得存儲與更新。本站提示廣大學習愛好者:(C#微信"平台開辟之access_token的獲得存儲與更新)文章只能為提供參考,不一定能成為您想要的結果。以下是C#微信"平台開辟之access_token的獲得存儲與更新正文
1、甚麼是access_token?
access_token是"號的全局獨一單子,"號挪用各接口時都需應用access_token。正常情形下access_token有用期為7200秒,反復獲得將招致前次獲得的access_token掉效。因為獲得access_token的api挪用次數異常無限,建議開辟者全局存儲與更新access_token,頻仍刷新access_token會招致api挪用受限,影響本身營業。
2、要處理的成績
1、若何獲得access_token。
2、因為access_token的有用期為7200秒,即2小時,而且反復獲得將招致前次獲得的access_token掉效,獲得access_token的api挪用次數異常無限,所以要處理若何全局存儲與更新access_token。
3、思緒
1、將access_token存儲在數據庫中。
2、什麼時候更新access_token呢?當access_token掉效的時刻更新,那末怎樣斷定access_token有無掉效呢?應用以後的access_token要求微信接口,獲得自界說菜單,假如前往的errcode為42001,則解釋access_token曾經掉效,這時候再從新獲得access_token。
數據庫設計(表名SWX_Config):
4、代碼:
1、Http要求代碼(HttpRequestUtil類):
#region 要求Url,不發送數據 /// <summary> /// 要求Url,不發送數據 /// </summary> public static string RequestUrl(string url) { return RequestUrl(url, "POST"); } #endregion #region 要求Url,不發送數據 /// <summary> /// 要求Url,不發送數據 /// </summary> public static string RequestUrl(string url, string method) { // 設置參數 HttpWebRequest request = WebRequest.Create(url) as HttpWebRequest; CookieContainer cookieContainer = new CookieContainer(); request.CookieContainer = cookieContainer; request.AllowAutoRedirect = true; request.Method = method; request.ContentType = "text/html"; request.Headers.Add("charset", "utf-8"); //發送要求並獲得響應回應數據 HttpWebResponse response = request.GetResponse() as HttpWebResponse; //直到request.GetResponse()法式才開端向目的網頁發送Post要求 Stream responseStream = response.GetResponseStream(); StreamReader sr = new StreamReader(responseStream, Encoding.UTF8); //前往成果網頁(html)代碼 string content = sr.ReadToEnd(); return content; } #endregion
2、幫助辦法(Tools類):
namespace SWX.Utils { /// <summary> /// 對象類 /// </summary> public class Tools { #region 獲得Json字符串某節點的值 /// <summary> /// 獲得Json字符串某節點的值 /// </summary> public static string GetJsonValue(string jsonStr, string key) { string result = string.Empty; if (!string.IsNullOrEmpty(jsonStr)) { key = "\"" + key.Trim('"') + "\""; int index = jsonStr.IndexOf(key) + key.Length + 1; if (index > key.Length + 1) { //先截逗號,若是最初一個,截“}”號,取最小值 int end = jsonStr.IndexOf(',', index); if (end == -1) { end = jsonStr.IndexOf('}', index); } result = jsonStr.Substring(index, end - index); result = result.Trim(new char[] { '"', ' ', '\'' }); //過濾引號或空格 } } return result; } #endregion } }
3、斷定access_token能否過時(WXApi類):
#region 驗證Token能否過時 /// <summary> /// 驗證Token能否過時 /// </summary> public static bool TokenExpired(string access_token) { string jsonStr = HttpRequestUtil.RequestUrl(string.Format("https://api.weixin.qq.com/cgi-bin/menu/get?access_token={0}", access_token)); if (Tools.GetJsonValue(jsonStr, "errcode") == "42001") { return true; } return false; } #endregion
4、要求微信接口,獲得access_token(WXApi類):
#region 獲得Token /// <summary> /// 獲得Token /// </summary> public static string GetToken(string appid, string secret) { string strJson = HttpRequestUtil.RequestUrl(string.Format("https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid={0}&secret={1}", appid, secret)); return Tools.GetJsonValue(strJson, "access_token"); } #endregion
5、全局存儲與更新access_token(AdminUtil類):
#region 獲得access_token /// <summary> /// 獲得access_token /// </summary> public static string GetAccessToken(PageBase page) { string access_token = string.Empty; UserInfo user = GetLoginUser(page); if (user != null) { if (string.IsNullOrWhiteSpace(user.access_token)) //還沒有保留過access_token { access_token = WXApi.GetToken(user.AppID, user.AppSecret); } else { if (WXApi.TokenExpired(user.access_token)) //access_token過時 { access_token = WXApi.GetToken(user.AppID, user.AppSecret); } else { return user.access_token; } } MSSQLHelper.ExecuteSql(string.Format("update SWX_Config set access_token='{0}' where UserName='{1}'", access_token, user.UserName)); } return access_token; } #endregion
出色專題分享:ASP.NET微信開辟教程匯總,迎接年夜家進修。
以上就是本文的全體內容,願望對年夜家停止微信"平台開辟有所贊助。