时间:2021-05-26
access_token
微信文档里存在两种access_token:普通 access_token 和 网页授权 access_token。具体区别参考:https://mp.weixin.qq.com/wiki?t=resource/res_main&id=mp1421140842
以下提到的 access_token 均为普通的 access_token
1. 首先我们先去看看是如何请求 access_token 的? 微信公众平台技术文档
GET请求:https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=APPID&secret=APPSECRET
正常返回:{"access_token":"ACCESS_TOKEN","expires_in":7200}
错误返回:{"errcode":40013,"errmsg":"invalid appid"}
2. 所以获取 access_token 的代码如下:
const request = require('request') // 请安装第三方包 requestrequest.get({ uri: 'https://api.weixin.qq.com/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
4. 现在把以上两块代码合并起来就是我们要的效果
const request = require('request')const guard_dog = require('guard_dog')guard_dog.init('ACCESS_TOKEN', (handler) => { request.get({ uri: 'https://api.weixin.qq.com/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.access_token, body.expires_in) })}) // 如有需要指定目录,可以再给 guard_dog.init 多传个参数5. guard_dog 初始化这个 key 之后,获取到的都是有效的值了。guard_dog 获取值代码如下:
guard_dog.get('ACCESS_TOKEN', (data) => { // 上面初始化时用的键名为'ACCESS_TOKEN',所以这里取值也要用这个键名 // 在这里拿到的 data 就是 access_token 了})6.如果想用着方便点,可以直接封装成一个模块
access_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.com/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.access_token, body.expires_in) })}) // 只要向外暴露一个获取值的方法就可以了module.exports = function (callback) { guard_dog.get('ACCESS_TOKEN', callback)}使用:
const access_token = require('./access_token') // 这里把这个模块与 access_token 模块当成在同一目录下来作为例子。access_token((data) => { // 这个 data 就是 access_token})jsapi_ticket
jsapi_ticket 官方文档说明
上面关于 access_token 的例子已经说得很详细了,jsapi_ticket 处理起来也大同小异,所以下面直接贴代码了:
(需要注意一点:获取 jsapi_ticket 需要依赖 access_token,下面的代码直接依赖了上面所写的 access_token.js)
jsapi_ticket.js
const request = require('request')const guard_dog = require('guard_dog')const access_token = require('./access_token')guard_dog.init('JSAPI_TICKET', (handler) => { access_token((access_token) => { request.get({ uri: 'https://api.weixin.qq.com/cgi-bin/ticket/getticket', json: true, qs: { access_token: access_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})以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
WechatJS-API接口功能:用于管理和获取微信JSSDK生产的access_token、jsapi_ticket和签名(signature)Install
一、获取流程1、获取access_token2、通过access_token换取jsapi_ticket3、签名算法签名生成规则如下:参与签名的字段包括nonc
首先不得不提到access_token的分类,一是普通access_token,二是网页授权access_token。其中前者是用于调用微信提供的各种借口,作为
前言:access_token是微信公众平台接口的重要参数,很多接口都需要这个参数。微信公众平台文档地址:微信公众平台技术文档一、access_token说明a
微信access_token设计的原理解析 1、access_token是加密的字符串,其目的是为了接口安全考虑,不然随便就能调用微信服务器的接口会有很大风险