基于koa2开发微信公众号(获取access_token)

在上篇文章当中,我们已经成功接入微信公众号,以为这样就把准备工作做好了,但是查看官方文档可以发现,还有一个必不可少的准备工作,那就是获取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,最后将该值再存放在文本文件当中。

你可能感兴趣的:(基于koa2开发微信公众号(获取access_token))