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微信開辟教程匯總,迎接年夜家進修。
以上就是本文的全體內容,願望對年夜家停止微信"平台開辟有所贊助。