L04-获取access_token的方法
L04-获取access_token的方法
1、方法定义:
读取本地文件(readAccessToken)
- 本地有文件
- 判断它是否过期(isValidAccessToken)
- 过期:重新请求获取access_token(getAccessToken),保存下来覆盖之前的文件(保证文件是唯一的)(saveAccessToken)
- 没有过期:直接使用
- 判断它是否过期(isValidAccessToken)
- 本地没有文件
- 发送请求获取access_token(getAccessToken),保存下来(本地文件)(saveAccessToken),直接使用
2、getAccessToken()
- 要引入config模块
- 需要下载request、request-promise-native模块,但只需要引入request-promise-native,终端输入
npm i request request-promise-native
进行下载
3、测试
const w = new Wechat();
w.getAccessToken();
结果如下:
4、计算失效时间
- 当前时间+7200s-5*60
5、需要外层getAccessToken方法返回这个值,所以用一个promise进行封装
6、saveAccessToken(accessToken)
- accessToken是一个对象,需要转换为JSON格式才能读取
- writeFile是一个异步方法,若要保证其能够进行保存,需要将其封装成一个promise对象
7、readAccessToken()
- 不需要参数
- data是一个json字符串,我们希望得到一个json对象,需要对其进行转化
8、isValidAccessToken(data)
- 先判断access_token是否有效
- 再判断access_token是否在有效期内
- 注意代码量的精简(注释部分的判断),直接用return可以判断后返回一个布尔值
9、测试:按照逻辑编写代码
- 运行结果如下:
- 同时,会生成一个accessToken的txt文件
本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来自 小新's Blog!
评论
Va