access_token是公众号的全局唯一接口调用凭据,公众号调用各接口时都需使用access_token。开发者需要进行妥善保存。access_token的存储至少要保留512个字符空间。access_token的有效期目前为2个小时,需定时刷新,重复获取将导致上次获取的access_token失效。
获取accessToken的接口地址为:https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=APPID&secret=APPSECRET,其中的两个参数:APPID和APPSECRET在微信管理后台都能够拿到。
我们在发送GET请求的时候,需要把这两个参数拼在链接后面。
我们之前还提到,accessToken的每日获取次数限制为2000次,因此我们需要在代码中做出处理,若当前请求距离上次不到7200秒,则直接读取缓存文件中的accessToken,若超过了7200秒,则重新请求接口,并将新获得的accessToken写入缓存文件储存起来。
showCode:
//我们先声明一个对象,对象中有一个方法:getAccessToken
getAccessToken:function(done){
const cacheFile = '.accesstoken.json';//缓存文件名
const instance = this;
const data = instance.readCacheFile(cacheFile);
const time = Math.round(Date.now() / 1000);
if (typeof data.expireTime === 'undefined' || data.expireTime < time) {
const url = `https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=${this.appId}&secret=${this.appSecret}`;
request.get(url, function (err, res, body) {//发送请求
if (err) {
return done(err, null);
}
try {
const data = JSON.parse(body);
instance.writeCacheFile(cacheFile, {
expireTime: Math.round(Date.now() / 1000) + 7200,
accessToken: data.access_token,
});
done(null, data.access_token);
} catch (e) {
done(e, null);
}
});
} else {
done(null, data.accessToken);
}
},
然后我们在需要用到的地方调用这个方法:
jsSdk.getAccessToken(function(err,accessToken){
if(err){
res.send(error);
return;
}
res.send(accessToken)
})
这样就能够保证accessToken接口不会超过当天的调用次数了。