首页 > 编程 > .NET > 正文

.Net微信开发之如何解决access_token过期问题

2024-07-10 12:46:58
字体:
来源:转载
供稿:网友

因为access_token,在以后的高级功能里面会经常用到,所以这里不得不这里对前面所讲解的access_token改造一下。
另外需要说明的是access_token是变化的,有自己的周期,官方解释为:"有效期为7200秒",这就要求我们把获得的access_token存入一个物理文件或者Application中,请求到过期后修改这些内容,需要用的时候读出来.
有些人可能想到了,如果过期我就在获得一个就好了,不用物理文件和Application也可以达到同样的效果,但是需要注意了微信平台对每天获得access_token的次数也作了限制,一个用户出发多次,如果用户多,那肯定就超出了。所以我们还是按照以上的思路实现这些功能:在此之前我们已经了解了获得access_token的方法(连接),现在只需要保证它的随时更新就好了.
首先建立一个Access_token类

/// <summary>///Access_token 的摘要说明/// </summary>public class Access_token{ public Access_token() { // //TODO: 在此处添加构造函数逻辑 // } string _access_token; string _expires_in; /// <summary> /// 获取到的凭证  /// </summary> public string access_token {  get { return _access_token; }  set { _access_token = value; } } /// <summary> /// 凭证有效时间,单位:秒 /// </summary> public string expires_in {  get { return _expires_in; }  set { _expires_in = value; } }}

用下面的XML文件来存放access_token,建立一个XMLFile.xml,把Access_YouXRQ标签的内容写成一个已经过去的时间,这样我们好在一开始调用的时候,发现已经过期,然后获取新的access_token。

<?xml version="1.0" encoding="utf-8"?><xml> <Access_Token>初始值可以随便写</Access_Token> <Access_YouXRQ>1980/12/12 16:06:38</Access_YouXRQ></xml>

改造一下之前获得Access_token的方法,让他给Access_token实例赋值

public static Access_token GetAccess_token() {  string appid = 你的appid ;  string secret = 你的secret;  string strUrl = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=" + appid + "&secret=" + secret;  Access_token mode = new Access_token();  HttpWebRequest req = (HttpWebRequest)HttpWebRequest.Create(strUrl);  req.Method = "GET";  using (WebResponse wr = req.GetResponse())  {   HttpWebResponse myResponse = (HttpWebResponse)req.GetResponse();   StreamReader reader = new StreamReader(myResponse.GetResponseStream(), Encoding.UTF8);   string content = reader.ReadToEnd();   //Response.Write(content);   //在这里对Access_token 赋值   Access_token token = new Access_token();   token = JsonHelper.ParseFromJson<Access_token>(content);   mode.access_token = token.access_token;   mode.expires_in = token.expires_in;  }  return mode; }            
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表