基于koa2開發(fā)微信公眾號(hào)(獲取access_token)

在上篇文章當(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)中。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容