在上篇文章當(dāng)中色徘,我們已經(jīng)成功接入微信公眾號(hào),以為這樣就把準(zhǔn)備工作做好了操禀,但是查看官方文檔可以發(fā)現(xiàn)褂策,還有一個(gè)必不可少的準(zhǔn)備工作,那就是獲取access_token床蜘,咦辙培?這不是在上一篇文章當(dāng)中有一個(gè)token(令牌)么蔑水,emm邢锯,此token非彼token,這個(gè)access_token是公眾號(hào)的全局唯一接口調(diào)用憑據(jù)搀别,公眾號(hào)調(diào)用各接口時(shí)都需使用access_token丹擎,有木有感覺到它的必要性!
既然需要那就獲取它唄歇父,但是問題在這個(gè)access_token每隔兩個(gè)小時(shí)就會(huì)刷新蒂培,而且新獲取的access_token會(huì)導(dǎo)致上一個(gè)失效,所以要統(tǒng)一獲取和刷新access_token才行榜苫。
具體的故事背景已經(jīng)了解了护戳,那么就來迎接這個(gè)挑戰(zhàn)吧!為了讓代碼層次清晰垂睬,在這里我新建了一個(gè)文件叫做wechat.js放在wechat文件夾下媳荒,具體的代碼如下抗悍。
//wechat.js主要代碼
const baseUrl="https://api.weixin.qq.com/";
const WxApi={
accessToken:baseUrl+"cgi-bin/token?grant_type=client_credential"
}
class WeChat{
constructor(opts){
this.appId=opts.appId;
this.appSecret=opts.appSecret;
this.getAccessToken=opts.getAccessToken;
this.saveAccessToken=opts.saveAccessToken;
this.init();//初始化
}
async init(){
//獲取access_token
let data=await this.getAccessToken();
//判斷讀取的內(nèi)容是否存在、是否為空字符串钳枕,如果是的話進(jìn)行更新
if(data && data.length!=0){
data=JSON.parse(data);
//判斷是否合法
if(!this.isValidAccessToken(data)){
data=await this.updateAccessToken();
}
}else{
data=await this.updateAccessToken();
}
this.access_token=data.access_token;
this.expires_in=data.expires_in;
this.saveAccessToken(JSON.stringify(data));
}
isValidAccessToken(data){
if(!data || !data.access_token || !data.expires_in){
return false;
}
return new Date().getTime() < data.expires_in ? true : false;
}
updateAccessToken(){
return new Promise(async (resolve,reject)=>{
var appId=this.appId;
var appSecret=this.appSecret;
var res = await koa2Req(WxApi.accessToken+"&appid="+appId+"&secret="+appSecret);
var data=JSON.parse(res.body);
data.expires_in=new Date().getTime() + (data.expires_in-20)*1000;
resolve(data);
});
}
}
//全局配置參數(shù) app.js部分代碼
const path=require('path');
const util=require('./libs/util');
const wechat_file=path.join(__dirname,'./config/wechat.txt');
var config={
appId:'wx262288ac63b56167',
appSecret:'e302745d129d5f9520dfd6d2d2408b8f',
token:'mytestdemo',
getAccessToken:function(){
return util.readFileAsync(wechat_file,'utf-8');
},
saveAccessToken:function(data){
return util.writeFileAsync(wechat_file,data);
}
}
//util.js 存放在libs文件夾下
var fs=require('fs');
exports.readFileAsync=function(fpath,encodning){
return new Promise((resolve,reject)=>{
fs.readFile(fpath,encodning,(err,content)=>{
if(err){
reject(err);
}
resolve(content);
});
});
}
exports.writeFileAsync=function(fpath,content){
return new Promise((resolve,reject)=>{
fs.writeFile(fpath,content,(err,content)=>{
if(err){
reject(err);
}
resolve();
});
});
}
從代碼中可以看出缴渊,當(dāng)新建一個(gè)WeChat實(shí)例的時(shí)候,其會(huì)初始化先拿到文本文件中存放的access_token鱼炒,再判斷該值是否有效衔沼,如果失效則更新當(dāng)前的access_token,最后將該值再存放在文本文件當(dāng)中昔瞧。