token失效 判断access_微信开发-ACCESS TOKEN 过期失效解决方案

本文介绍了在微信开发中遇到ACCESS TOKEN过期失效的问题及其解决方案。通过建立公共access token数据,在有效期内重复使用,过期时重新获取。核心代码包括获取access_token、jsapi_ticket的方法,以及文件存储和更新策略。
摘要由CSDN通过智能技术生成

微信开发-ACCESS TOKEN 过期失效解决方案

起因:因为access_token的重要性,开发过微信的都知道,但是他有自己的生命周期,官方解释为:"有效期为7200秒",一天调用2000次。流量一高,就over了,没办法,龙哥不帮我们解决问题,我们就要自己解决,不能等死。

解决思路很简单:建立公共access token数据,有效期内不重新创建access_token。

解决方案:

1、微信类库:有效期内直接读取access token数据文件中的json数据,过期失效,重新获取并创建新的access token数据文件

2、数据文件:存放有效的access token数据,具体有:access_token.json和jsapi_ticket.json

核心代码如下:

Index: wxjsSDK.cs

===================================================================

--- wxjsSDK.cs(revision 0)

+++ wxjsSDK.cs(revision 1)

@@ -0,0 +1,209 @@

+using System;

+using System.Collections.Generic;

+using System.Web;

+using System.IO;

+using System.Security.Cryptography;

+using System.Runtime.Serialization.Json;

+using System.Runtime.Serialization;

+using System.Net;

+using System.Runtime.Serialization.Formatters.Binary;

+using System.Text;

+

+namespace JR.Common

+{

+ public class wxjsSDK

+ {

+ private string appId;

+ private string appSecret;

+

+

+ public wxjsSDK(string appId, string appSecret)

+ {

+ this.appId = appId;

+ this.appSecret = appSecret;

+ }

+

+

+

+ //得到数据包,返回使用页面

+ public System.Collections.Hashtable getSignPackage()

+ {

+ string jsapiTicket = getJsApiTicket();

+ string url = HttpContext.Current.Request.Url.ToString(); //"http://$_SERVER[HTTP_HOST]$_SERVER[REQUEST_URI]";

+ string timestamp = Convert.ToString(ConvertDateTimeInt(DateTime.Now));

+ string nonceStr = createNonceStr();

+ // 这里参数的顺序要按照 key 值 ASCII 码升序排序

+ string rawstring = "jsapi_ticket=" + jsapiTicket + "&noncestr=" + nonceStr + "&timestamp=" + timestamp + "&url=" + url + "";

+ string signature = SHA1_Hash(rawstring);

+ var signPackage = new System.Collections.Hashtable();

+ signPackage.Add("appId", appId);

+ signPackage.Add("nonceStr", nonceStr);

+ signPackage.Add("timestamp", timestamp);

+ signPackage.Add("url", url);

+ signPackage.Add("signature", signature);

+ signPackage.Add("rawString", rawstring);

+ return signPackage;

+ }

+

+

+ //创建随机字符串

+ private string createNonceStr()

+ {

+ int length = 16;

+ string chars = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789";

+ string str = "";

+ var rad = new Random();

+ for (int i = 0; i < length; i++)

+ {

+ str += chars.Substring(rad.Next(0, chars.Length - 1), 1);

+ }

+ return str;

+ }

+

+

+ //得到ticket 如果文件里时间 超时则重新获取

+ private string getJsApiTicket()

+ {

+ string ticket = "";

+ // jsapi_ticket 应该全局存储与更新,以下代码以写入到文件中做示例

+ string path = HttpContext.Current.Server.MapPath(@"/log/jssdk/jsapi_ticket.json");

+ if (!File.Exists(path))

+ {

+ File.Create(path).Close();

+ }

+ StreamReader sr = new StreamReader(path, System.Text.Encoding.Default);

+ string filecontent = sr.ReadToEnd();

+ CommonJsonModel jsonModel = null;

+ if (!string.IsNullOrEmpty(filecontent))

+ {

+ jsonModel = new CommonJsonModel(filecontent);

+ }

+ sr.Close();

+ sr.Dispose();

+ if (jsonModel == null || int.Parse(jsonModel.GetValue("expires_in")) < ConvertDateTimeInt(DateTime.Now))

+ {

+ string accessToken = getAccessToken();

+ string url = "https://api.weixin.qq.com/cgi-bin/ticket/getticket?type=jsapi&access_token=" + accessToken;

+ jsonModel = new CommonJsonModel(httpGet(url));

+ ticket = jsonModel.GetValue("ticket");

+ if (ticket != "")

+ {

+ string json = "{\"ticket\":\"" + ticket + "\",\"expires_in\":" + (ConvertDateTimeInt(DateTime.Now) + 7000) + "}";

+ StreamWriterMetod(json, path);

+ }

+ }

+ else

+ {

+ ticket = jsonModel.GetValue("ticket");

+ }

+ return ticket;

+ }

+

+

+ //得到accesstoken 如果文件里时间 超时则重新获取

+ private string getAccessToken()

+ {

+ // access_token 应该全局存储与更新,以下代码以写入到文件中做示例

+ string access_token = "";

+ string path = HttpContext.Current.Server.MapPath(@"/log/jssdk/access_token.json");

+ if (!File.Exists(path))

+ {

+ File.Create(path).Close();

+ }

+ StreamReader sr = new StreamReader(path, System.Text.Encoding.Default);

+ string filecontent = sr.ReadToEnd();

+ CommonJsonModel jsonModel = null;

+ if (!string.IsNullOrEmpty(filecontent))

+ {

+ jsonModel = new CommonJsonModel(filecontent);

+ }

+ sr.Close();

+ sr.Dispose();

+ if (jsonModel == null || int.Parse(jsonModel.GetValue("expires_in")) < ConvertDateTimeInt(DateTime.Now))

+ {

+ string url = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=" + appId +

+ "&secret=" + appSecret + "";

+ jsonModel = new CommonJsonModel(httpGet(url));

+ access_token = jsonModel.GetValue("access_token");

+ if (access_token != "")

+ {

+ string json = "{\"access_token\":\"" + access_token + "\",\"expires_in\":" + (ConvertDateTimeInt(DateTime.Now) + 7000) + "}";

+ StreamWriterMetod(json, path);

+ }

+ }

+ else

+ {

+ access_token = jsonModel.GetValue("access_token");

+ }

+ return access_token;

+ }

+

+

+ //发起一个http请球,返回值

+ private string httpGet(string url)

+ {

+ try

+ {

+ var MyWebClient = new WebClient();

+ MyWebClient.Credentials = CredentialCache.DefaultCredentials; //获取或设置用于向Internet资源的请求进行身份验证的网络凭据

+ Byte[] pageData = MyWebClient.DownloadData(url); //从指定网站下载数据

+ string pageHtml = System.Text.Encoding.Default.GetString(pageData);//如果获取网站页面采用的是GB2312,则使用这句

+ //string pageHtml = Encoding.UTF8.GetString(pageData); //如果获取网站页面采用的是UTF-8,则使用这句

+ return pageHtml;

+ }

+ catch (WebException webEx)

+ {

+ Console.WriteLine(webEx.Message.ToString());

+ return null;

+ }

+ }

+

+

+ //SHA1哈希加密算法

+ private string SHA1_Hash(string str_sha1_in)

+ {

+ SHA1 sha1 = new SHA1CryptoServiceProvider();

+ byte[] bytes_sha1_in = System.Text.UTF8Encoding.Default.GetBytes(str_sha1_in);

+ byte[] bytes_sha1_out = sha1.ComputeHash(bytes_sha1_in);

+ string str_sha1_out = BitConverter.ToString(bytes_sha1_out);

+ str_sha1_out = str_sha1_out.Replace("-", "").ToLower();

+ return str_sha1_out;

+ }

+

+

+ ///

+ /// StreamWriter写入文件方法

+ ///

+ private void StreamWriterMetod(string str, string patch)

+ {

+ FileStream stream = new FileStream(patch, FileMode.OpenOrCreate, FileAccess.Write, FileShare.Delete | FileShare.ReadWrite);

+ StreamWriter writer = new StreamWriter(stream);

+ writer.WriteLine(str);

+ stream.Flush();

+ writer.Close();

+ stream.Close();

+ stream.Dispose();

+ writer.Dispose();

+ }

+

+

+

+

+ ///

+ /// 将c# DateTime时间格式转换为Unix时间戳格式

+ ///

+ /// 时间

+ /// double

+ private int ConvertDateTimeInt(System.DateTime time)

+ {

+ int intResult = 0;

+ System.DateTime startTime = TimeZone.CurrentTimeZone.ToLocalTime(new System.DateTime(1970, 1, 1));

+ intResult = Convert.ToInt32((time - startTime).TotalSeconds);

+ return intResult;

+ }

+

+

+ }

+

+

+}

access_token.json

{"access_token":"4H14BVCUrAxxxxxxxxxxxxWeLu-zKETaBYqsoKFjsHZDc3xOwc-m43WDw2HjzxEkng2nC7iJuHydNt5PqRDY7HCoAU4lmuaPoYsIQHdW9kA","expire_time":1428599121}

access_token.json

{"jsapi_ticket":"bxLdikRXVbTPdHSM05e5u1wgoccccccccccccccccccccccccccccc11FFzYsiqbXZN0SDGN6Dnksnt2Q","expire_time":1428599122}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 当微信开发工具提示 "access_token is invalid or not latest"(access_token无效或者不是最新的)时,这通常表示当前使用的access_token过期或者已被撤销,需要重新获取一个最新的access_token。 在微信开发中,access_token是用来进行微信接口调用的重要凭证。由于access_token的有效期较短(通常为2小时),因此在开发过程中,需要定期刷新access_token,以确保能够正常调用微信接口。 获取最新的access_token可以通过向微信服务器发送请求来获取。具体的获取方法是向微信服务器发送GET请求,请求地址为https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=APPID&secret=APPSECRET,其中APPID为微信公众号的AppID,APPSECRET为微信公众号的AppSecret。 获取到最新的access_token后,需要将其保存起来,并在每次调用微信接口时进行使用。同时,定时刷新access_token是一个良好的开发习惯,可以避免由于access_token过期而导致的接口调用失败。 所以,当微信开发工具提示 "access_token is invalid or not latest"时,我们需要检查当前的access_token是否过期,如果过期则通过上述步骤获取一个最新的access_token,并更新到开发工具中,以确保能够正常进行微信接口的调用。 ### 回答2: 微信开发工具给出"access_token is invalid or not latest"这个提示,意味着使用的access_token无效或者不是最新的。 access_token是用于调用微信开放平台接口的重要凭证,每个应用都需要获取有效的access_token才能进行接口的访问和操作。验证access_token是否有效和最新主要考虑以下两个因素: 1. 有效性:access_token的有效期为2小时,超过2小时后需要重新获取新的access_token。所以如果提示是无效的,可能是因为已经过期了,需要重新获取新的access_token。 2. 最新性:在获取access_token之后,如果有进一步的操作(例如获取或更新用户信息、发布消息等),可能会导致access_token被刷新。这样旧的access_token失效,需要使用最新的access_token才能继续操作。提示不是最新的access_token可能是因为在之前的操作中,access_token已经被刷新过了。 解决这个问题的方法是: 1. 检查access_token是否已经过期了,如果过期了,则需要重新获取新的access_token。 2. 如果access_token是最新的,那么可能是因为在之前的操作中,access_token已经被刷新过了。解决方法是更新代码中的access_token,使用最新的access_token进行后续操作。 总之,当微信开发工具提示"access_token is invalid or not latest"时,开发者需要验证并更新access_token,确保它的有效性和最新性,以确保后续接口调用的成功。 ### 回答3: 微信开发工具提示"access_token is invalid or not latest"是由于我们在使用微信开发接口时,所使用的access_token无效或者不是最新的。 在使用微信开发接口时,我们需要先获取一个access_token,它是调用微信开发接口的凭证。access_token是有时效性的,一般在2小时后会过期,我们需要定期更新。如果我们在使用时使用了一个无效的或者过期access_token微信开发工具就会提示"access_token is invalid or not latest"。 出现这个问题的原因可能有以下几点: 1. access_token过期:在获取access_token后,由于时间过长或者其他原因,我们没有及时更新和使用新的access_token。 2. 缓存和保存问题:我们没有正确地缓存和保存access_token,导致在使用时被认为是无效或者过期的。 3. 接口调用限制:我们在一定时间内调用接口的次数超过了微信的限制,导致access_token被封禁或者自动失效。 解决这个问题的方法是: 1. 定期更新access_token:我们可以设置一个定时任务,在access_token接近过期时自动更新。也可以在每次使用之前都重新获取一次access_token。 2. 正确缓存和保存access_token:在获取access_token后,将其正确地缓存和保存起来,在使用时及时获取和更新。 3. 规避接口调用限制:合理控制接口的调用频率,避免在一定时间内调用过多次导致访问受限。 总之,微信开发工具提示"access_token is invalid or not latest"是因为我们使用了无效或者过期access_token,我们需要定期更新access_token,并正确地缓存和保存它,同时合理控制接口的调用频率,以解决这个问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值