2021年5月19日星期三

使用NodeJs作为微信公众号后台服务器 使用node回复公众号消息 node验证公众号tonken node微信公众号开发

使用NodeJs作为微信公众号后台服务器

下面演示代码的源码地址 https://gitee.com/szxio/weChatServer

申请测试公众号

首先登录微信公众平台,选择自己的公众号登录。登录成功后点击开发者工具,选择公众平台测试账号

点击进去后我们可以申请一个测试用的公众号,可以体验所有高级接口,这里我们要配置一个线上的接口地址,在验证 Tonken,和收发消息时微信都会请求我们配置的地址,这里推荐一个好用的内网穿透工具,可以把我们本地的项目地址映射到外网上,方便我们调试

小米球内网穿透工具

这里我生成的线上地址是 src="https://gitee.com/szxio/weChatServer/raw/master/public/image/2.png" alt="image-20210518191538886" loading="lazy">

实现Tonken验证

首先新建一个空白的 node 项目

npm init -y

接着安装一些常用的依赖

npm install express

接在在项目根路径下新建 index.js,初始代码如下

const express = require("express")const app = express()app.get("/",(req,res)=>{ res.send('Hello World')})app.listen(8088,()=>{ console.log("running 127.0.0.1:8088");})

然后启动项目并用浏览器访问 127.0.0.1:8088可以看到如下结果,表示服务启动成功

现在我们实现验证 tonken 的逻辑

首先安装如下依赖,用作加密处理

npm install crypto

然后新建 utilrouter 两个文件夹,分别放置我们的统一的方法和普通请求方法

然后新建 util -> validateToken.js 文件,代码如下,这个方法专门用来验证微信传递过来的 Tonken

var crypto = require("crypto");// 加密方法function sha1(str) { var md5sum = crypto.createHash("sha1"); md5sum.update(str); str = md5sum.digest("hex"); return str;}// 验证tonkenfunction validateToken(req) { return new Promise((resolve, reject) => { let query = req.query; let signature = query.signature; let echostr = query["echostr"]; let timestamp = query["timestamp"]; let nonce = query["nonce"]; let oriArray = new Array(); oriArray[0] = nonce; oriArray[1] = timestamp; oriArray[2] = "admin123"; // 这里是在公众号接口配置信息里面填写的Token oriArray.sort(); let original = oriArray.join(""); let scyptoString = sha1(original); if (signature == scyptoString) {  // 验证通过,返回 echostr  resolve(echostr); } else {  reject(false); } });}// 导出验证 Tonken 的发放module.exports = validateToken;

然后新建 router -> weChat.js 文件,这个文件专门用来处理微信发送过来的请求,在这个文件中编写如下代码

const express = require("express");const router = express.Router(); // 配置路由模块const validateToken = require("../util/validateToken");// get请求验证tonken有效性router.get("/", (req, res) => { validateToken(req).then((t) => { res.send(t); });});// 导出 routermodule.exports = router;

最后修改一下index.js文件,引入我们新建的 router.js 文件

const express = require("express");const app = express();const path = require("path");const weChat = require(path.resolve(__dirname, "./router/weChat"));app.use(weChat);app.listen(8088, () => { console.log("running 127.0.0.1:8088");});

现在我们去微信公众号配置页面中测试一下

image-20210519162630934

页面中弹出 配置成功 就表示我们验证 Tonken 的业务已经完成了

获取Tonken并定时刷新

微信中获取 Tonken 要发送一个 get 请求来获取,并且这个 Tonken 有过期时间,我们需要自己保存这个 Tonken 并定时刷新,以保证 Tonken 有效性

微信官方对于获取 Tonken 的描述

接口调用说明

  • 请求方式: GET
  • 请求地址:https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=APPID&secret=APPSECRET

既然要用到请求,我们安装一个 axios 用来发送请求

npm install axios

然后在根目录新建 public -> tonken.json ,用来存放我们获取到的 tonken,也是对 tonken 的一种持久化存储方式,json文件内容为空即可

接着新建 util -> tonkenConfig.js 文件,代码如下

const fs = require("fs");const path = require("path");const http = require("axios");const fileUrl = path.resolve(__dirname, "../public/tonken.json");const APPID = "wx2188729b190d357d"; // 测试号的 APPIDconst APPSECRET = "d976b0e6262b829ba003e9a24032447c"; // 测试号的 APPSECRETlet INTERTIME = (7200 - 60) * 1000; // 设置一个默认的定期获取tonken的时间// 保存Tonkenfunction setTonken() { return new Promise((resolve, reject) => { http  .get(  `https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=${APPID}&secret=${APPSECRET}`  )  .then((res) => {  // 更新tonken的过期时间,每隔这个时间重新获取一次tonken  INTERTIME = (res.data.expires_in - 60) * 1000;  // 获取到Tonken后保存到json文件中  fs.writeFile(   fileUrl,   JSON.stringify({   tonken: res.data.access_token,   }),   () => {   // 通知外界Tonken获取成功   resolve();   }  );  }); });}// 定时获取Tonkenfunction timingSetTonken() { // 定时刷新tonken setInterval(() => { setTonken(); }, INTERTIME);}// 获取Tonkenfunction getTonken() { return new Promise((resolve, reject) => { // 从json中读取保存的Tonken fs.readFile(fileUrl, (err, data) => {  // 返回获取到的tonken  resolve(JSON.parse(data).tonken); }); });}// 导出封装好的方法module.exports = { setTonken, // 更新tonken getTonken, // 返回获取到的tonken timingSetTonken, // 定时更新tonken};

然后在 router -> weChat.js 中引入 tonkenConfig.js

const express = require("express");const router = express.Router(); // 配置路由模块const validateToken = require("../util/validateToken");const { setTonken, timingSetTonken } = require("../util/tonkenConfig");// 项目启动后自动执行获取tonken的方法setTonken().then(() => { // tonken 获取成功后开始定时刷新tonken操作 timingSetTonken();});// get请求验证tonken有效性router.get("/", (req, res) => { validateToken(req).then((t) => { res.send(t); });});// 导出 routermodule.exports = router;

此时我们在启动项目后会自动调用一下获取 tonken 的接口,然后从接口中获取到一个过期时间,微信返回的过期时间是以秒为单位,减去60秒是为了下一次tonken时与这次tonken之间的平滑过渡,之后每隔这个时间会重新获取一次tonken

我们将这个tonken写入到了一个json文件中,我们可以在任何文件中通过如下方法获取tonken

const { getTonken } = require("./util/tonkenConfig");// 调用封装好的获取token方法getTonken().then((tonken) => { console.log(tonken); // 45_7k55HHRaYxM4MkD4aREraHZpgdjmT......});

接收微信消息并回复

官方对于接收消息的描述

简单说就是:我们在微信公众号中发送消息后,微信会发送一个 post 请求给我们上面配置的地址,参数时一段 文本,我们需要解析这个 ,并按照微信指定的格式回复一个 格式的字符串,注意是回复

首先安装依赖,用来解析post请求中的参数

npm install express-

然后在 index.js 文件中引用并配置中间件

const express = require("express");const app = express();const path = require("path");const weChat = require(path.resolve(__dirname, "./router/weChat"));const 

然后在 weChat.js 中添加一个 post 请求,打印一下看看微信给我们发过来的是什么东西

// post请求处理微信发送过来的消息router.post("/", (req, res) => { console.log(req.body); res.send("");});

重启项目,我们往微信公众号中随便发送一个消息

解析后的参数如下

{ 

拿到参数后我们可以根据参数中的 msgtype 判断传递过来的消息类型,以及 content 是消息内容,获取到了参数,接下要做的就是根据消息回复内容了

官方被动回复用户消息文档

下面是一个回复消息的模板代码,可以很方便的帮助我们生成指定的 格式的字符串

// 回复文本消息exports.textMessage = function (message) { var createTime = new Date().getTime(); return `<

weChat.js 中引入上面的模板,这里我把模板代码放到了 util -> template.js 中,然后修改刚刚新建的 post 方法

// 引入消息模板const template = require("../util/template");// post请求处理微信发送过来的消息router.post("/", (req, res) => { let 

我们现在在发送消息试一试

我们看到公众号已经可以回答我们了。









原文转载:http://www.shaoqun.com/a/752799.html

跨境电商:https://www.ikjzd.com/

预售:https://www.ikjzd.com/w/889

三维度:https://www.ikjzd.com/w/1312


使用NodeJs作为微信公众号后台服务器下面演示代码的源码地址https://gitee.com/szxio/weChatServer申请测试公众号首先登录微信公众平台,选择自己的公众号登录。登录成功后点击开发者工具,选择公众平台测试账号点击进去后我们可以申请一个测试用的公众号,可以体验所有高级接口,这里我们要配置一个线上的接口地址,在验证Tonken,和收发消息时微信都会请求我们配置的地址,这里
焦点科技:https://www.ikjzd.com/w/1831
photobucket:https://www.ikjzd.com/w/132
tiki:https://www.ikjzd.com/w/2053
站外推广;三招解决goole关键词排名上不去的问题!:https://www.ikjzd.com/articles/16003
晦暗街灯下我和他在车里疯狂爱爱:http://www.30bags.com/m/a/251241.html
口述:女邻居爱爱太高调每晚都叫:http://lady.shaoqun.com/m/a/18818.html

没有评论:

发表评论