Node.js微信 access_token ( jsapi_ticket ) 存取与刷新的示

网络编程 2021-07-04 17:32www.168986.cn编程入门
本篇文章主要介绍了Node.js微信 aess_token ( jsapi_ticket ) 存取与刷新的示例,具有一定的参考价值,有兴趣的可以了解一一下‘

aess_token

微信文档里存在两种aess_token普通 aess_token 和 网页授权 aess_token。具体区别参考

以下提到的 aess_token 均为普通的 aess_token

1. 我们先去看看是如何请求 aess_token 的?

GET请求

正常返回{"aess_token":"ACCESS_TOKEN","expires_in":7200}

错误返回{"errcode":40013,"errmsg":"invalid appid"}

2. 所以获取 aess_token 的代码如下

const request = require('request') // 请安装第三方包 request

request.get({
  uri: 'https://api.weixin.qq./cgi-bin/token',
  json: true,
  qs: {
   grant_type: 'client_credential',
   appid: APPID, // APPID请换成你的 appid
   secret: APPSECRET // APPSECRET请换成你的 appsecret
  }
 }, (err, res, body) => {
  if (err) {
   console.log(err)
   return
  }
  console.log(body)
  if (body.errcode) {
   // 返回错误时的处理
   return
  }
})

3. guard_dog 实现数据持久化和定时刷新

guard_dog 会生成 .dog 文件,每个文件对应一个KEY

const guard_dog = require('guard_dog') // 请安装第三方包 guard_dog

guard_dog.init(KEY, (handler) => { // KEY是guard_dog存取数据的键名
 // 拿到数据后调用 handler
 handler(DATA, EXPIREDS_IN) // DATA是要持久化的数据,EXPIREDS_IN是数据的有效时间,单位是秒
}, DIR) // DIR是 .dog 文件的存放目录,这个参数可以不传

4. 现在把以上两块代码合并起来就是我们要的效果

const request = require('request')
const guard_dog = require('guard_dog')

guard_dog.init('ACCESS_TOKEN', (handler) => {
 request.get({
  uri: 'https://api.weixin.qq./cgi-bin/token',
  json: true,
  qs: {
   grant_type: 'client_credential',
   appid: APPID, // APPID请换成你的 appid
   secret: APPSECRET // APPSECRET请换成你的 appsecret
  }
 }, (err, res, body) => {
  if (err) {
   console.log(err)
   return
  }
  console.log(body)
  if (body.errcode) {
   return
  }
  handler(body.aess_token, body.expires_in)
 })
}) // 如有需要指定目录,可以再给 guard_dog.init 多传个参数

5. guard_dog 初始化这个 key 之后,获取到的都是有效的值了。guard_dog 获取值代码如下

guard_dog.get('ACCESS_TOKEN', (data) => { // 上面初始化时用的键名为'ACCESS_TOKEN',所以这里取值也要用这个键名
 // 在这里拿到的 data 就是 aess_token 了
})

6.如果想用着方便点,可以直接封装成一个模块

aess_token.js

const request = require('request')
const guard_dog = require('guard_dog')
// 加载这个模块的时候给 ACCESS_TOKEN 这个键名初始化
guard_dog.init('ACCESS_TOKEN', (handler) => {
 request.get({
  uri: 'https://api.weixin.qq./cgi-bin/token',
  json: true,
  qs: {
   grant_type: 'client_credential',
   appid: APPID, // APPID请换成你的 appid
   secret: APPSECRET // APPSECRET请换成你的 appsecret
  }
 }, (err, res, body) => {
  if (err) {
   console.log(err)
   return
  }
  console.log(body)
  if (body.errcode) {
   return
  }
  handler(body.aess_token, body.expires_in)
 })
}) 
// 只要向外暴露一个获取值的方法就可以了
module.exports = function (callback) {
 guard_dog.get('ACCESS_TOKEN', callback)
}

使用

const aess_token = require('./aess_token') // 这里把这个模块与 aess_token 模块当成在同一目录下来作为例子。
aess_token((data) => {
 // 这个 data 就是 aess_token
})

jsapi_ticket


上面关于 aess_token 的例子已经说得很详细了,jsapi_ticket 处理起来也大同小异,所以狼蚁网站SEO优化直接贴代码了

(需要注意一点获取 jsapi_ticket 需要依赖 aess_token,狼蚁网站SEO优化的代码直接依赖了上面所写的 aess_token.js)

jsapi_ticket.js

const request = require('request')
const guard_dog = require('guard_dog')
const aess_token = require('./aess_token')

guard_dog.init('JSAPI_TICKET', (handler) => {
 aess_token((aess_token) => {
  request.get({
   uri: 'https://api.weixin.qq./cgi-bin/ticket/getticket',
   json: true,
   qs: {
    aess_token: aess_token,
    type: 'jsapi'
   }
  }, (err, res, body) => {
   if (err) {
    console.log(err)
    return
   }
   console.log(body)
   if (body.errcode) {
    return
   }
   handler(body.ticket, body.expires_in)
  })
 })
})

module.exports = function (callback) {
 guard_dog.get('JSAPI_TICKET', callback)
}

使用

const jsapi_ticket = require('./jsapi_ticket')
jsapi_ticket((data) => {
 // 这个 data 就是 jsapi_ticket
})

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持狼蚁SEO。

Copyright © 2016-2025 www.168986.cn 狼蚁网络 版权所有 Power by