时间:2021-05-26
上一篇:自动回复的实现
这两天终于把获取access_token+自定义菜单+授权登录+获取用户信息部分完成了,nodejs其实不是很熟悉,所以估计有很多特性没用起来的,还有很多冗余代码以及各种问题,只能说功能实现了,大家多多担待吧。
获取access_token
因为调用所有公众号的接口都需要用到access_token,所以必须先将access_token缓存起来,方便以后使用,access_token的有效时间为2小时,所以需要定时更新,下面是代码实现。
有一点需要注意,本文会提到两个access_token,还有一个是oauth时会用到,所以大家不要搞混了。
access_token的获取
access_token的获取相对来说很简单了,就是请求一个链接附加参数得到access_token,代码如下:
const getAccessToken = function () { let queryParams = { 'grant_type': 'client_credential', 'appid': config.appId, 'secret': config.appSecret }; let wxGetAccessTokenBaseUrl = 'https://api.weixin.qq.com/cgi-bin/token?'+qs.stringify(queryParams); let options = { method: 'GET', url: wxGetAccessTokenBaseUrl }; return new Promise((resolve, reject) => { request(options, function (err, res, body) { if (res) { resolve(JSON.parse(body)); } else { reject(err); } }); })};请求的三个参数也比较简洁:
参数 是否必须 说明 grant_type 是 获取access_token填写client_credential appid 是 第三方用户唯一凭证 secret 是 第三方用户唯一凭证密钥,即appsecret
access_token的保存
保存有很多种方法,放在缓存里等,我这边是存放在一个文件里,因为仅仅是一个示例,定时7000s更新。
//保存与更新const saveToken = function () { getAccessToken().then(res => { let token = res['access_token']; fs.writeFile('./token', token, function (err) { }); })};const refreshToken = function () { saveToken(); setInterval(function () { saveToken(); }, 7000*1000);};这样access_token就能做到定时更新了,注意,如果不是测试好获取token的次数是有限制的,不过一般没什么问题,测试最好还是在测试号上进行。
自定义菜单
获取access_token后自定义菜单的实现就非常简单了,这里仅仅简单讲一下请求,具体菜单内容请看微信的文档。
http请求方式:POST(请使用https协议) https://api.weixin.qq.com/cgi-bin/menu/create?access_token=ACCESS_TOKEN
但是body要带上菜单的内容,就是json数据,但是微信返回的数据是string类型,所以下面也要注意,可能在这边会遇到问题。简单代码如下:
'use strict';const fs = require('fs');const request = require('request');//token,因为token是存在文件里的所以这里进行文件读取得到tokenconst token = fs.readFileSync('./token').toString();//常用type为view和click,分别为点击事件和链接var menus = { "button": [ { "name": "测试菜单", "sub_button": [ { "type": "view", "name": "授权登录", "url": "http://wuyrsp3tma.proxy.qqbrowser.cc/auth" }] }]};function createMenu() { let options = { url: 'https://api.weixin.qq.com/cgi-bin/menu/create?access_token=' + token, form: JSON.stringify(menus), headers: { 'Content-Type': 'application/x-/xiadd/shorthand 欢迎star以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
用户自定义菜单制作时,需要用到access_token,我们直接使用前面讲解的IsExistAccess_Token()函数。我理解的微信公共平台里面菜单分为b
上一篇:获取access_token+自定义菜单这部分代码是之前就已经完成了,但是考虑篇幅的问题就和上篇分开了,这部分相较前面的方式较为复杂一点,但是也是很容易
微信自定义菜单编辑器是一款基于NW、JS(webkit+node)开发的微信公众号自定义菜单查询、编辑、发布小工具,软件功能非常强大实用,支持本地部署保证App
微信订阅号自定义菜单教程来咯~下文将演示微信订阅号自定义菜单申请流程,订阅号如何才能够设置自定义菜单呢?如果你想要知道方法的话就请继续往下看吧。 订阅号要
怎么给微信公众号开发自定义菜单,下面小编以最简单的方式来交大家1、登入微信公众平台,点击进入自定义菜单2、创建菜单名称,以及菜单内容。3、勾选发送消息。跳转网页