位置: 编程技术 - 正文

详解Node.js access_token的获取、存储及更新(详解金球奖之争)

编辑:rootadmin

推荐整理分享详解Node.js access_token的获取、存储及更新(详解金球奖之争),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:详解中国女足出线形势,详解杭州亚运会会徽和口号,详解增发万亿国债细节,详解增发万亿国债细节,详解中国航天三垂一远,详解增发万亿国债细节,详解增发万亿国债细节,详解杭州亚运会会徽和口号,内容如对您有帮助,希望把文章链接给更多的朋友!

一、写在前面的话

上一篇文章中,我们使用 Node.js 成功的实现了接入微信公众平台功能。在这篇文章中,我们将实现微信公众平台一个非常重要的参数 access_token ,它是公众号的全局唯一接口调用凭据,公众号调用各接口时都需使用 access_token。

在开始之前,让我们先按捺住自己激动的心情、调整好呼吸,因为我们要将上一篇文章的代码重新整理一下。一个好的项目结构,更能有助于我们理清业务逻辑以及将来维护代码的便捷。OK?

二、整理项目结构

1.打开我们的项目,并在项目中添加文件夹,命名为 wechat ,如图:

2.在 wechat 文件夹中添加文件并命名为 wechat.js。wechat.js 主要用于封装开发微信公众平台的所有方法。首先我们构建这个模块的结构,代码如下:

严格模式:是在 ECMAScript 5 中引入的概念。严格模式是为 Javascript 定义了一种解析与执行模型。

module.exports :暴露接口用于外部操作。实际上我们定义模块后,使用 node.js 的 require 引用时,node.js 会自动在我们定义的模块外层加入以下代码

相信对于有过 javascript 开发经验的同学,上面的代码并不陌生。我们可以将它理解为一个闭包,是一个匿名方法的调用,避免污染全局变量。

小知识:

在上面的代码中,除了我们所使用的 module.exports 对象,还有另一个用于暴露接口的 变量 exports (官方文档将 module.exports 称为对象,exports 称为 属性,我在这里也就这样称呼了),那么 module.exports 与 exports 有什么区别呢?

module.exports 对象是由模块系统创建的,exports 变量是在模块的文件级别作用域内有效的,它在模块被执行前被赋于 module.exports 的值。——来自Node.js官方文档

也就是说 exports 是 module.exports 的引用,而 module.exports 才是真正用于暴露接口的对象。 exports 赋值的所有属性与方法都赋值给了 module.exports 对象。

如果 module.exports 与 exports 将值赋值给了相同的属性,则按照赋值的先后顺序,取最后一个赋值;如果我们给 module.exports 赋值的是一个对象,则会覆盖 exports 的所有方法与属性。

因此我们在暴露接口的使用上,如果只是单一属性或方法的话,建议使用exports.属性/方法,要是导出多个属性或方法或使用对象构造方法,建议使用 module.exports。

3.为 WeChat 对象添加一个方法 auth,并将 app.js 中的验证方法粘贴进去

4.整理 app.js 文件的中的代码,如下:

嗯!这样代码看着是不是舒服多了呢。机智如我

剩下的就是去微信公众平台接入验证了,在上一篇文章中有详细的教程,这里我就不再演示了

就是这么懒

三、access_token的获取、存储及更新

1.微信文档步骤

详解Node.js access_token的获取、存储及更新(详解金球奖之争)

在开始码代码之前,我们依然是先理清实现的思路,在开始编写实现代码。打开 微信帮助文档 ,点击左侧菜单中的开始开发,点击其子菜单获取access_token,如图:

通过上面的 API 的描述,我们总结出以下步骤:

1.实现 https Get 请求

2.获取 access_token 并存储 如果 当前 access_token 过期则更新

2.access_token的获取、存储及更新 代码实现

整理好思路后我们就按照上一节的步骤去实现。通过帮助文档我们将用于请求微信API 的请求地址与参数,存放到 config.json 文件。

其中 appid 与 secret 两个参数 位于 微信公众平台 左侧菜单的基本配置中,如图:

开发者密码 点击重置,用手机微信扫面二维码后便可得到。config.json 代码如下

由于微信 API 请求连接的域名是公用的,我们将它提出来,在请求地址中使用 %s(字符串) 占位符占位。

微信所有请求连接都是 https 协议,很幸运的是 Node.js 系统包中为我们提供了 https 的包,由于后面的请求会多次用到 https ,因此我们将它封装为一个公用的方法,以便以后的使用,再次打开 wechat.js 在构造方法中,引入 https 模块,并在构造函数内部添加 requestGet 方法

提示:

npm 提供了很多用于请求的工具包,比如 request ( 安装命令 npm install request ) 等。这里我只是用系统包去做请求处理。

由于 https 是异步请求的,我在这里面使用了 ES6 的 Promise 对象 。

完成了 requestGet方法后,我们的第1步骤也就完成了。下面开始第2步,获取 access_token 并存储 如果 当前 access_token 过期则更新。

在这之前我是想将 access_token 的存储位置依然放在 config.json 文件中,由于 access_token 在更新后 需要将文件重写,可能容易造成 config.json 文件的格式的紊乱,因此在 wechat 中重新创建一个 accessToken.json 文件用于存储 access_token

其中 access_token 用于存储 我们 GET 请求后access_token 的值,expires_time 用于存储 access_token 的过期时间,保存为时间戳。

在 wechat.js 引入 fs 模块用于操作文件、util 工具模块用于处理占位符、 accessToken.json 文件

在 wechat.js 添加获取 access_token 的方法 getAccessToken

在 app.js 中添加新的监听链接用于测试 我们获取的token

这样我们就大功告成了!

标签: 详解金球奖之争

本文链接地址:https://www.jiuchutong.com/biancheng/382112.html 转载请保留说明!

上一篇:深入浅析Nodejs的Http模块(nodejs cgi)

下一篇:NodeJs中express框架的send()方法简介(node.jsexpress)

  • 商贸企业购销混凝土税率怎么选择
  • 企业所得税留抵税额会显示在申报表上吗?
  • 税务局退税多久到账
  • 税务系统纳税申报
  • 小规模纳税人为什么没有进项
  • 先包装后销售先销售后包装的消费税处理
  • 增值税普通发票需要交税吗
  • 小规模定额征收是怎样
  • 利息费用和利息支出的区别计算公式
  • 应解汇款科目
  • 公司租房子出去物业费可以代付吗
  • 年报中纳税总额怎么填
  • 个体户销售蔬菜免增值税吗
  • 公司拖欠工资还要继续工作吗?
  • 旅行社代订机票怎么做账
  • 公益性捐赠公告
  • 不动产增值税总结
  • 长期零申报的公司容易注销吗
  • 商业承兑汇票贴现为什么是短期借款
  • 2021年如何申报海外收入
  • 申请办理银行承兑流程
  • 非营利性组织有
  • 确认递延收益纳税调整吗
  • 无票收入报税后,后期又开票出去怎么处理?
  • 处置股权后相应债权坏账损失怎么处理?
  • 电子普通发票怎么开
  • win 11bug
  • 购买一台电脑会计分录
  • win10如何关闭windows安全中心图标
  • 什么是资产负债率,如何计算
  • 高新技术企业职工总数
  • 自制生产设备领用原材料按照什么确认收入
  • 前端如何调用后端方法
  • 堡垒山是哪个国家
  • python进行傅立叶变换
  • 其他债权投资如何进行投资收益的确认的核算?
  • 计提租金怎么做会计分录
  • dedecms51
  • 财政借钱给预算单位的会计处理
  • 我有朋友吗朋友圈说说
  • 小规模纳税人交通运输服务税率
  • 本月记账之前是不是要结转上月
  • 园林绿化行业的市场需求是什么
  • 金税盘锁死341101
  • 转出未交增值税借方余额表示什么
  • 生产企业支付的房租怎么入账
  • 购入固定资产的增值税计入成本吗
  • 长期股权投资权益法账务处理
  • 工程上第三方代表啥意思
  • 一次性购买多张火车票
  • windows mysql1045
  • mysql求两个字段的和
  • mysql count详解及函数实例代码
  • 服务器 安装win10
  • linux文件系统损坏
  • windows7 设置
  • ubuntu 15.04系统怎么安装qq?
  • win8怎么共享电脑
  • win8怎么看windows
  • windows电脑图片传到iphone
  • linux安装与基本命令
  • win10系统桌面图标大小怎么设置
  • win10无法安装无线显示器
  • div left
  • perl教程 pdf
  • osg uniform
  • 分享五个有用的东西
  • mac 安卓系统
  • 使用androidx 找不到v7
  • javascript+HTML5 Canvas绘制转盘抽奖
  • javascript获取html元素的方法
  • JavaScript+html5 canvas制作的百花齐放效果完整实例
  • 面向对象设计六大原则
  • python搭建平台
  • 基于javascript创建导航页面
  • 广州市税务局机构设置
  • 东城国税局局长
  • 西乡国税局电话
  • 电子票据如何报销
  • 环保税申报操作手册
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设