node微信開發之獲取access_token+自定義菜單

這篇文章主要介紹了node微信開發之獲取access_token+自定義菜單,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨着小編來一起學習學習吧

上一篇:自動回覆的實現

這兩天終於把獲取access_token+自定義菜單+授權登錄+獲取用戶信息部分完成了,nodejs其實不是很熟悉,所以估計有很多特性沒用起來的,還有很多冗餘代碼以及各種問題,只能說功能實現了,大家多多擔待吧。

獲取access_token

因爲調用所有公衆號的接口都需要用到access_token,所以必須先將access_token緩存起來,方便以後使用,access_token的有效時間爲2小時,所以需要定時更新,下面是代碼實現。

有一點需要注意,本文會提到兩個access_token,還有一個是oauth時會用到,所以大家不要搞混了。

access_token的獲取

access_token的獲取相對來說很簡單了,就是請求一個鏈接附加參數得到access_token,代碼如下:

const getAccessToken = function () {
 let queryParams = {
  'grant_type': 'client_credential',
  'appid': config.appId,
  'secret': config.appSecret
 };

 let wxGetAccessTokenBaseUrl = 'https://api.weixin.qq.com/cgi-bin/token?'+qs.stringify(queryParams);
 let options = {
  method: 'GET',
  url: wxGetAccessTokenBaseUrl
 };
 return new Promise((resolve, reject) => {
  request(options, function (err, res, body) {
   if (res) {
    resolve(JSON.parse(body));
   } else {
    reject(err);
   }
  });
 })
};

請求的三個參數也比較簡潔:

參數 是否必須 說明
grant_type 獲取access_token填寫client_credential
appid 第三方用戶唯一憑證
secret 第三方用戶唯一憑證密鑰,即appsecret

access_token的保存

保存有很多種方法,放在緩存裏等,我這邊是存放在一個文件裏,因爲僅僅是一個示例,定時7000s更新。

//保存與更新
const saveToken = function () {
 getAccessToken().then(res => {
  let token = res['access_token'];
  fs.writeFile('./token', token, function (err) {
   
  });
 })
};

const refreshToken = function () {
 saveToken();
 setInterval(function () {
  saveToken();
 }, 7000*1000);
};

這樣access_token就能做到定時更新了,注意,如果不是測試好獲取token的次數是有限制的,不過一般沒什麼問題,測試最好還是在測試號上進行。

自定義菜單

獲取access_token後自定義菜單的實現就非常簡單了,這裏僅僅簡單講一下請求,具體菜單內容請看微信的文檔。
http請求方式:POST(請使用https協議) https://api.weixin.qq.com/cgi-bin/menu/create?access_token=ACCESS_TOKEN

但是body要帶上菜單的內容,就是json數據,但是微信返回的數據是string類型,所以下面也要注意,可能在這邊會遇到問題。簡單代碼如下:

'use strict';
const fs = require('fs');
const request = require('request');

//token,因爲token是存在文件裏的所以這裏進行文件讀取得到token
const token = fs.readFileSync('./token').toString();

//常用type爲view和click,分別爲點擊事件和鏈接
var menus = {
 "button": [
  {
   "name": "測試菜單",
   "sub_button": [
    {
     "type": "view",
     "name": "授權登錄",
     "url": "http://wuyrsp3tma.proxy.qqbrowser.cc/auth"
    }]
  }]
};

function createMenu() {
 let options = {
  url: 'https://api.weixin.qq.com/cgi-bin/menu/create?access_token=' + token,
  form: JSON.stringify(menus),
  headers: {
   'Content-Type': 'application/x-www-form-urlencoded'
  }
 };
 
 request.post(options, function (err, res, body) {
  if (err) {
   console.log(err)
  }else {
   console.log(body);
  }
 })
 
}

module.exports = createMenu;

這樣在服務器啓動的時候調用這個模塊就可以創建一個簡單的自定義菜單了:

好這部分就算結束了,本來想連着jssdk一起的但是那樣就顯得太長了,但是那部分代碼已經完成了,所以大家可以自行看看代碼。

github地址奉上:https://github.com/xiadd/shorthand 歡迎star

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持神馬文庫。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章