基于koa2开发微信公众号(获取access_token)
2018-11-29 本文已影响0人
lk儒家
在上篇文章当中,我们已经成功接入微信公众号,以为这样就把准备工作做好了,但是查看官方文档可以发现,还有一个必不可少的准备工作,那就是获取access_token,咦?这不是在上一篇文章当中有一个token(令牌)么,emm,此token非彼token,这个access_token是公众号的全局唯一接口调用凭据,公众号调用各接口时都需使用access_token,有木有感觉到它的必要性!
既然需要那就获取它呗,但是问题在这个access_token每隔两个小时就会刷新,而且新获取的access_token会导致上一个失效,所以要统一获取和刷新access_token才行。
具体的故事背景已经了解了,那么就来迎接这个挑战吧!为了让代码层次清晰,在这里我新建了一个文件叫做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();
//判断读取的内容是否存在、是否为空字符串,如果是的话进行更新
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);
});
}
}
//全局配置参数 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();
});
});
}
从代码中可以看出,当新建一个WeChat实例的时候,其会初始化先拿到文本文件中存放的access_token,再判断该值是否有效,如果失效则更新当前的access_token,最后将该值再存放在文本文件当中。