node.js 微信開發之定時獲取access_token
什麼是access_token
access_token是公眾號的全域性唯一票據,公眾號呼叫各介面時都需使用access_token。開發者需要進行妥善儲存。access_token的儲存至少要保留512個字元空間。access_token的有效期目前為2個小時,需定時重新整理,重複獲取將導致上次獲取的access_token失效
當你的多個微信開發相關服務並存時,多個服務各自去獲取 access_token,最後導致其中一些服務會不能正常訪問.
所以這種情況下,應該設定一個獲取 access_token 的中控伺服器.
因為 access_token 的有效期為 2個小時,
所以你的中控伺服器必須能夠定時去拉取最新的 access_token .
下面我們設定一個非常簡單的中控伺服器
此中控伺服器需要有以下幾個特點:
1.可以定時執行
2.拉取到最新 access_token 可以持久化
3.持久化的access_token 可以被其他相關服務訪問到.
node.js下定時任務
我們採用 node-schedule
npm install node-schedule --save
schedule.scheduleJob(A,B)
scheduleJob 方法接收2個引數,A 為日期規則 (多長時間執行) B 為回撥方法 (當日期符合條件時,將要做什麼)
先來看下引數 A :
##六顆星方式
‘* * * * * *'
┬ ┬ ┬ ┬ ┬ ┬
│ │ │ │ │ └ 星期幾 (0 - 7) ( 0 或者 7 表示星期日 )
│ │ │ │ └───── 月份 (1 - 12)
│ │ │ └────────── 日期 (1 - 31)
│ │ └─────────────── 小時 (0 - 23)
│ └──────────────────── 分鐘 (0 - 59)
└───────────────────────── 秒 (0 - 59)
下面用此方式我們約定在 8月30日0點0分0秒 執行程式.
對應的引數A 設定如下:
‘0 0 0 30 8 *'
var m= schedule.scheduleJob('0 0 0 30 8 *',function(){ getToken(); });
上面的 getToken() 是我自定義的一個獲取微信 access_token 的方法,下面會有說明.
設定每30秒執行一次定時任務
‘30 * * * * *'
設定每1分30秒執行一次任務
‘30 1 * * * *'
設定凌晨0點1分30秒執行任務
‘30 1 0 * * *'
RecurrenceRule 方式
//定義一個時間規則 var rule = new schedule.RecurrenceRule(); // rule.dayOfWeek = 0; // rule.month = 0; // rule.dayOfMonth = 0; // rule.hour = 0; // rule.minute = 0; rule.second = 0; schedule.scheduleJob(rule,function(){ getToken(); });
建立了一個 RecurrenceRule 物件,它有6個屬性,分別對應 星期,月份,日期,小時,分鐘,秒
通過各個引數來設定你的時間規則器.
上面介紹了 node.js 下使用 node-schedule 來執行定時任務,下面我們來看下如何獲取微信 access_token
獲取微信 access_token
GET 請求方式:
https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid={APPID}&secret={APPSECRET}
注意上面的 {APPID} 和 {APPSECRET} 要登入微信公眾後臺獲取.
下面我們使用 request 來提交一個get 請求即可:
npm install request --save
我們還用到了 redis,npm install redis --save
var client=redis.createClient({ "host":"127.0.0.1","port":"6379" }); var getToken=function(){ var url=util.format('https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=%s&secret=%s',wechat.appid,wechat.secret); request(url,function(error,response,body){ if (!error && response.statusCode == 200) { var bodyToken=JSON.parse(body); if(bodyToken&&bodyToken.access_token){ setToken(bodyToken.access_token); } } }) } var setToken=function(token){ if(token){ client.set("YG-WECHAT-TOKEN",token); } }
每小時執行一次定時任務 getToken()
拿到最新 access_token 後儲存在 redis 中,key 為 YG-WECHAT-TOKEN
獲取 access_token
上面的流程我們已經每小時讓定時任務拿到了最新的 access_token,並且持久化到了 redis 中.
其他服務如何獲取 access_token 呢?
直接連線 redis 服務,根據 key 獲取對應的 token.
當然你也可以寫一個統一的介面,通過介面拿到 access_token.