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

首先建立一个Access_token类

  

 1     /// <summary>
2 ///Access_token 的摘要说明
3 /// </summary>
4 public class Access_token
5 {
6 public Access_token()
7 {
8 //
9 //TODO: 在此处添加构造函数逻辑
10 //
11 }
12 string _access_token;
13 string _expires_in;
14
15 /// <summary>
16 /// 获取到的凭证
17 /// </summary>
18 public string access_token
19 {
20 get { return _access_token; }
21 set { _access_token = value; }
22 }
23
24 /// <summary>
25 /// 凭证有效时间,单位:秒
26 /// </summary>
27 public string expires_in
28 {
29 get { return _expires_in; }
30 set { _expires_in = value; }
31 }
32 }
 1     /// <summary>
2 ///Access_token 的摘要说明
3 /// </summary>
4 public class Access_token
5 {
6 public Access_token()
7 {
8 //
9 //TODO: 在此处添加构造函数逻辑
10 //
11 }
12 string _access_token;
13 string _expires_in;
14
15 /// <summary>
16 /// 获取到的凭证
17 /// </summary>
18 public string access_token
19 {
20 get { return _access_token; }
21 set { _access_token = value; }
22 }
23
24 /// <summary>
25 /// 凭证有效时间,单位:秒
26 /// </summary>
27 public string expires_in
28 {
29 get { return _expires_in; }
30 set { _expires_in = value; }
31 }
32 }

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

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

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

1     public static Access_token GetAccess_token()
2 {
3 string appid = 你的appid ;
4 string secret = 你的secret;
5 string strUrl = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=" + appid + "&secret=" + secret;
6 Access_token mode = new Access_token();
7
8 HttpWebRequest req = (HttpWebRequest)HttpWebRequest.Create(strUrl);
9
10 req.Method = "GET";
11 using (WebResponse wr = req.GetResponse())
12 {
13 HttpWebResponse myResponse = (HttpWebResponse)req.GetResponse();
14
15 StreamReader reader = new StreamReader(myResponse.GetResponseStream(), Encoding.UTF8);
16
17 string content = reader.ReadToEnd();
18 //Response.Write(content);
19 //在这里对Access_token 赋值
20 Access_token token = new Access_token();
21 token = JsonHelper.ParseFromJson<Access_token>(content);
22 mode.access_token = token.access_token;
23 mode.expires_in = token.expires_in;
24 }
25 return mode;
26 }
 1     public static Access_token GetAccess_token()
2 {
3 string appid = 你的appid ;
4 string secret = 你的secret;
5 string strUrl = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=" + appid + "&secret=" + secret;
6 Access_token mode = new Access_token();
7
8 HttpWebRequest req = (HttpWebRequest)HttpWebRequest.Create(strUrl);
9
10 req.Method = "GET";
11 using (WebResponse wr = req.GetResponse())
12 {
13 HttpWebResponse myResponse = (HttpWebResponse)req.GetResponse();
14
15 StreamReader reader = new StreamReader(myResponse.GetResponseStream(), Encoding.UTF8);
16
17 string content = reader.ReadToEnd();
18 //Response.Write(content);
19 //在这里对Access_token 赋值
20 Access_token token = new Access_token();
21 token = JsonHelper.ParseFromJson<Access_token>(content);
22 mode.access_token = token.access_token;
23 mode.expires_in = token.expires_in;
24 }
25 return mode;
26 }

以上的方法用到了Json对象的处理,所以我把JsonHelper的代码一贴出来供大家参考,一下就是JsonHelper.cs的代码:

1     using System;
2 using System.IO;
3 using System.Text;
4 using System.Runtime.Serialization.Json;
5
6
7
8 public class JsonHelper
9 {
10 /// <summary>
11 /// 生成Json格式
12 /// </summary>
13 /// <typeparam name="T"></typeparam>
14 /// <param name="obj"></param>
15 /// <returns></returns>
16 public static string GetJson<T>(T obj)
17 {
18 DataContractJsonSerializer json = new DataContractJsonSerializer(obj.GetType());
19 using (MemoryStream stream = new MemoryStream())
20 {
21 json.WriteObject(stream, obj);
22 string szJson = Encoding.UTF8.GetString(stream.ToArray()); return szJson;
23 }
24 }
25 /// <summary>
26 /// 获取Json的Model
27 /// </summary>
28 /// <typeparam name="T"></typeparam>
29 /// <param name="szJson"></param>
30 /// <returns></returns>
31 public static T ParseFromJson<T>(string szJson)
32 {
33 T obj = Activator.CreateInstance<T>();
34 using (MemoryStream ms = new MemoryStream(Encoding.UTF8.GetBytes(szJson)))
35 {
36 DataContractJsonSerializer serializer = new DataContractJsonSerializer(obj.GetType());
37 return (T)serializer.ReadObject(ms);
38 }
39 }
40 }
 1     using System;
2 using System.IO;
3 using System.Text;
4 using System.Runtime.Serialization.Json;
5
6
7
8 public class JsonHelper
9 {
10 /// <summary>
11 /// 生成Json格式
12 /// </summary>
13 /// <typeparam name="T"></typeparam>
14 /// <param name="obj"></param>
15 /// <returns></returns>
16 public static string GetJson<T>(T obj)
17 {
18 DataContractJsonSerializer json = new DataContractJsonSerializer(obj.GetType());
19 using (MemoryStream stream = new MemoryStream())
20 {
21 json.WriteObject(stream, obj);
22 string szJson = Encoding.UTF8.GetString(stream.ToArray()); return szJson;
23 }
24 }
25 /// <summary>
26 /// 获取Json的Model
27 /// </summary>
28 /// <typeparam name="T"></typeparam>
29 /// <param name="szJson"></param>
30 /// <returns></returns>
31 public static T ParseFromJson<T>(string szJson)
32 {
33 T obj = Activator.CreateInstance<T>();
34 using (MemoryStream ms = new MemoryStream(Encoding.UTF8.GetBytes(szJson)))
35 {
36 DataContractJsonSerializer serializer = new DataContractJsonSerializer(obj.GetType());
37 return (T)serializer.ReadObject(ms);
38 }
39 }
40 }

其实还可以直接饮用Newtonsoft.Json.dll可以直接操作json,这样更方便一些。

我们还需要写一个判断access_token是否过期如果过期更新XML文件的方法。

1     /// <summary>
2 /// 根据当前日期 判断Access_Token 是否超期 如果超期返回新的Access_Token 否则返回之前的Access_Token
3 /// </summary>
4 /// <param name="datetime"></param>
5 /// <returns></returns>
6 public static string IsExistAccess_Token()
7 {
8
9 string Token = string.Empty;
10 DateTime YouXRQ;
11 // 读取XML文件中的数据,并显示出来 ,注意文件路径
12 string filepath = Server.MapPath("XMLFile.xml");
13
14 StreamReader str = new StreamReader(filepath, System.Text.Encoding.UTF8);
15 XmlDocument xml = new XmlDocument();
16 xml.Load(str);
17 str.Close();
18 str.Dispose();
19 Token = xml.SelectSingleNode("xml").SelectSingleNode("Access_Token").InnerText;
20 YouXRQ = Convert.ToDateTime(xml.SelectSingleNode("xml").SelectSingleNode("Access_YouXRQ").InnerText);
21
22 if (DateTime.Now > YouXRQ)
23 {
24 DateTime _youxrq = DateTime.Now;
25 Access_token mode = GetAccess_token();
26 xml.SelectSingleNode("xml").SelectSingleNode("Access_Token").InnerText = mode.access_token;
27 _youxrq = _youxrq.AddSeconds(int.Parse(mode.expires_in));
28 xml.SelectSingleNode("xml").SelectSingleNode("Access_YouXRQ").InnerText = _youxrq.ToString();
29 xml.Save(filepath);
30 Token = mode.access_token;
31 }
32 return Token;
33 }
 1     /// <summary>
2 /// 根据当前日期 判断Access_Token 是否超期 如果超期返回新的Access_Token 否则返回之前的Access_Token
3 /// </summary>
4 /// <param name="datetime"></param>
5 /// <returns></returns>
6 public static string IsExistAccess_Token()
7 {
8
9 string Token = string.Empty;
10 DateTime YouXRQ;
11 // 读取XML文件中的数据,并显示出来 ,注意文件路径
12 string filepath = Server.MapPath("XMLFile.xml");
13
14 StreamReader str = new StreamReader(filepath, System.Text.Encoding.UTF8);
15 XmlDocument xml = new XmlDocument();
16 xml.Load(str);
17 str.Close();
18 str.Dispose();
19 Token = xml.SelectSingleNode("xml").SelectSingleNode("Access_Token").InnerText;
20 YouXRQ = Convert.ToDateTime(xml.SelectSingleNode("xml").SelectSingleNode("Access_YouXRQ").InnerText);
21
22 if (DateTime.Now > YouXRQ)
23 {
24 DateTime _youxrq = DateTime.Now;
25 Access_token mode = GetAccess_token();
26 xml.SelectSingleNode("xml").SelectSingleNode("Access_Token").InnerText = mode.access_token;
27 _youxrq = _youxrq.AddSeconds(int.Parse(mode.expires_in));
28 xml.SelectSingleNode("xml").SelectSingleNode("Access_YouXRQ").InnerText = _youxrq.ToString();
29 xml.Save(filepath);
30 Token = mode.access_token;
31 }
32 return Token;
33 }

好了,完成了上面的工作,我只需要在使用到access_token的时调用如下就OK了,“客户再也不用担心token的过期”
string _access_token = IsExistAccess_Token();

微信公共平台开发5 .net的更多相关文章

  1. ASP.NET MVC 微信公共平台开发之获取用户消息并处理

    ASP.NET MVC 微信公共平台开发 获取用户消息并处理 获取用户消息 用户发送的消息是在微信服务器发送的一个HTTP POST请求中包含的,获取用户发送的消息要从POST请求的数据流中获取 微信 ...

  2. ASP.NET MVC 微信公共平台开发之验证消息的真实性

    ASP.NET MVC 微信公共平台开发 验证消息的真实性 在MVC Controller所在项目中添加过滤器,在过滤器中重写 public override void OnActionExecuti ...

  3. ASP.NET MVC 微信公共平台开发之 微信接入

    ASP.NET MVC 接入微信公共平台 申请微信公共账号 既然要接入微信公共平台,微信公共号是必须的(当然如果只是测试的话也可以申请微信公共平台接口测试账号),来这里微信公共平台 申请微信公共号(注 ...

  4. 微信公共平台开发-(.net实现)1--成为开发者

    刚换了个新环境,哎这都快一个月了,还没适应过来,还是怀念老地方呀.老板让开发一个基于微信平台的开发项目,而且是用net实现.当时就蒙了,微信就用了一会个人赶脚不好,所以果断不用,现在让开发,而且查了一 ...

  5. 微信公共平台开发1 .net

    如果想通过微信去开发(当然,指的是开发模式下),首先 建议先申请一个服务号,因为服务号的功能与接口也多,有些功能订阅号是实现不了的.另外申请过以后必须得通过微信 认证才能开发,好像是得付300大洋,高 ...

  6. 微信公共平台开发-(.net实现)5--access_token过期的问题

    每次在于微信交互时,都要用到access_token,但是这个值限制的是有时间的,但是access_token,在以后的高级功能里面会经常用到,所以这里不得不这里对前面所讲解的access_token ...

  7. 微信公共平台开发-(.net实现)3--发送文本消息

    最近,项目这边比较忙,没来得及续写,哎,先吐吐槽吧,在这个周六还得来上班,以后每个周六多要上,一天的滋味真有点受不鸟呀.还不习惯ing... 嗯,别的不说了现在开始接着上次http://www.cnb ...

  8. 微信公共平台开发-(.net实现)2--ACCESSTOKEN值获得

    成功的走出第一步后,我们紧接着趁热打铁开始下一步: 成为了开发者之后微信平台会给您AppId和AppSecret,在订阅号中是没有的,所以因该申请一下服务号, 若没有请注意上一篇http://www. ...

  9. 微信公共平台开发3 .net

    嗯,别的不说了现在开始接着上次http://www.cnblogs.com/QLJ1314/p/3838058.html  获取ACCESSTOKEN,开始吧,接下来我们就写发送文本消息吧. 首先建立 ...

随机推荐

  1. 关于STM8的用户数据空间读写问题

    情况是这样的,我的程序里有一个参数,数值不超过1000,我要保存到EEPROM中,那就要分两个字节存放.我用下面的方式保存是正常的: BASE = 0x4000; param = 999; eepro ...

  2. Cannot open connection 解决办法

    试了很多种网上找的办法,都不行,最后才发现是我的beans.xml中完全把下面 这一段代码给遗忘了,忘记写了.添加我就ok了. 我能说花了我近1个小时吗?坑姐哦! <bean class=&qu ...

  3. GPT分区基础知识

    大硬盘和WIN8系统,让我们从传统的BIOS+MBR模式升级到UEFI+GPT模式,现在购买的电脑,都是预装WIN8系统,为了更好的支持2TB硬盘,更快速的启动win8,预装系统都采取了GPT分区的格 ...

  4. 一种读取Exchange的用户未读邮件数方法!

    已好几个月没写博客了,由于之前忙于开发基于Sharepoint上的移动OA(AgilePoint)和采用混合移动开发技术开发一个安卓版的企业通讯录APP(数据与lync一致),并于1月初正式上线.马年 ...

  5. 安卓开发笔记——探索EventBus

    1.关于EventBus: 组件通讯在Android开发中是不可避免的,随着业务需求的复杂化,代码中需要我们去处理的业务逻辑难度也不断增大.例如多个Fragment之间的数据传递,Service与Ac ...

  6. Java-基本的程序设计结构

    Java-基本的程序设计结构 >注释 Java的注释分为三种情况 第一种://开头 第二种:"/*" 开头 "*/"结尾 上面两种情况跟C#.C++.Ob ...

  7. 移动WEB开发中媒体查询里的width, device-width, resolution

    /*1.width: viewport的宽度,css像素,三星S3的viewort默认宽度是980px. 当设置viewport width=device-width时,对应的媒体查询中width的值 ...

  8. codeforces B. Design Tutorial: Learn from Life

    题意:有一个电梯,每一个人都想乘电梯到达自己想要到达的楼层!从a层到b层的时间是|a-b|, 乘客上下电梯的时间忽略不计!问最少需要多少的时间....     这是一道神题啊,自己的思路不知不觉的就按 ...

  9. java中图片文件的传输及显示(Socket以及ServerSocket演示)

    //客户端部分 package testSix; import java.awt.Graphics; import java.io.IOException; import java.io.InputS ...

  10. ServiceStack.Redis 中关系操作的局限与bug

    redis是文档型的,nosql中难处理的是关系. 比如人可以发博客,博客可以有分类.按照传统sql中,用户表和分类表都是主表,博客表是从表,有用户的外键和分类的外键 如果使用文档型的思考方式. 为用 ...