摘要:微信文档里存在两种普通和网页授权。这个就是官方文档说明上面关于的例子已经说得很详细了,处理起来也大同小异,所以下面直接贴代码了需要注意一点获取需要依赖,下面的代码直接依赖了上面所写的使用这个就是
access_token
微信文档里存在两种access_token:普通 access_token 和 网页授权 access_token。具体区别参考:https://mp.weixin.qq.com/wiki...
以下提到的 access_token 均为普通的 access_token
1. 首先我们先去看看是如何请求 access_token 的? 微信公众平台技术文档2. 所以获取 access_token 的代码如下:GET请求:https://api.weixin.qq.com/cgi...
正常返回:{"access_token":"ACCESS_TOKEN","expires_in":7200}
错误返回:{"errcode":40013,"errmsg":"invalid appid"}
const request = require("request") // 请安装第三方包 request 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 } })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.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 })
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/88792.html
摘要:本篇主要讲述,如何在微信中打开自家的页面,在然后在用户分享的时候,能由我们自定义分享出去后,展示的页面卡片中的页面标题页面描述页面图片和分享链接。 本篇主要讲述,如何在微信中打开自家的页面,在然后在用户分享的时候,能由我们自定义分享出去后,展示的页面卡片中的页面标题、页面描述、页面图片和分享链接。 此功能,具体的来说,是: 在微信打开自家的页面 点击右上角微信的功能按钮,出现功能菜单...
摘要:最近开发微信公众号内嵌页面,使用搭建的项目,由于业务需求,需要实现微信自定义分享功能,所以项目中集成微信。 最近开发微信公众号内嵌H5页面,使用vue搭建的项目,由于业务需求,需要实现微信自定义分享功能,所以项目中集成微信JS-SDK。微信JS-SDK是微信公众平台面向网页开发者提供的基于微信内的网页开发工具包。通过使用微信JS-SDK,网页开发者可借助微信高效地使用拍照、选图、语音、...
摘要:准备工作申请服务器公众号基本配置这些微信公众平台上都有,就不介绍了,接下来进入正题。随着微信管控越发严厉,像一些最基本的网页转发都需要授权处理才能获取到图片和描述,描述审查也是相当严格。 准备工作: 申请服务器 公众号 基本配置 这些微信公众平台上都有,就不介绍了,接下来进入正题。 ➣ 微信网页授权 node js-sdk 授权公众平台的技术文档目的为了简明扼要的交代接口的使用,语句难...
摘要:进过下面的步骤,一步一步的配置,就可以让你正确的在项目中引入微信的。在进行了正确的微信文件引入后看上面在页面中调用如下代码就可以注入权限验证配置。可以通过微信提供的两个接口来进行事件回调。到这为止,微信的接入就完成了。 微信JS-SDK的功能 如果你点进来,那么我相信你应该知道微信的JS-SDK可以用来做什么了。微信的官方文档描述如下。 微信JS-SDK是微信公众平台面向网页开发者提供...
阅读 3446·2021-11-25 09:43
阅读 1003·2021-11-15 11:36
阅读 3294·2021-11-11 16:54
阅读 3918·2021-09-27 13:35
阅读 4323·2021-09-10 11:23
阅读 5538·2021-09-07 10:22
阅读 3009·2021-09-04 16:40
阅读 748·2021-08-03 14:03