node.js微信小程序配置消息推送的实现


Posted in Javascript onFebruary 13, 2019

在开发微信小程序时,有一个消息推送,它的解释是这样的。

消息推送具体的内容是下面的这个网址   https://developers.weixin.qq.com/miniprogram/dev/framework/server-ability/message-push.html,他介绍的也还可以,就是我这里换成了node代码。

消息推送

启用并设置消息推送配置后,用户发给小程序的消息以及开发者需要的事件推送,都将被微信转发至该服务器地址中。

在微信小程序的首页开发里面,开发设置中,微信的官网中,介绍的也还可以,php代码写的差不多也能了解什么意思,但是其中没有告诉我们要把echostr这个参数在接口中返回出来,所以导致我测试了半天都是那个Token验证失败。

写一下学习记录吧,方便后来的人遇到同样的问题,也方便自己以后查阅。

node.js微信小程序配置消息推送的实现

这个里面的url服务器地址就是自己的地址(上面那个是我随便写的),后面接上自己的接口,比如我的就是 /token,当你点击提交的时候,会发现在服务器中会有如下的get请求

node.js微信小程序配置消息推送的实现

避免有些人看不清楚上面的我在这里再用代码重新写一下上面的东西。

GET /checkPushMsg?signature=db6e0c25b7743d8dd7ebfda1db6c742a762a2f37&echostr=1712804002525306855×tamp=1549949926&nonce=982754662 200 1.321 ms - 46

其中的各个参数微信官网中介绍的也非常的详细。

node.js微信小程序配置消息推送的实现

开发者通过检验 signature 对请求进行校验(下面有校验方式)。若确认此次 GET 请求来自微信服务器,请原样返回 echostr 参数内容,则接入生效,成为开发者成功,否则接入失败。加密/校验流程如下:

  • 将token、timestamp、nonce三个参数进行字典序排序
  • 将三个参数字符串拼接成一个字符串进行sha1加密
  • 开发者获得加密后的字符串可与signature对比,标识该请求来源于微信

验证URL有效性成功后即接入生效,成为开发者。

检验signature的node.js示例代码:

/*
 验证服务器推送url地址
 开发者提交信息后,微信服务器将发送GET请求到填写的服务器URL上,GET请求携带参数如下
   @params signature 微信加密签名,signature结合了开发者填写的token参数和请求中的timestamp参数,nonce参数
   @params timestamp  时间戳
   @params nonce  随机数
   @params echostr  随机字符串
*/
exports.check_push = (req, res) => {
 console.log(req.query);
 let signature = req.query.signature,
   timestamp = req.query.timestamp,
   nonce = req.query.nonce,
   echostr = req.query.echostr;
 let a = crypto.createHash('sha1').update([pushToken, timestamp, nonce].sort().join('')).digest('hex'); // 这里的pushToken就是在上面的那里配置的Token

 if(a == signature){
  // 如果验证成功则原封不动的返回
  res.send(echostr);
 }else{
  res.send({
   status: 400,
   data: "check msg error"
  })
 }
};

其中遇到的两个问题,上面已经说了,这里再说一下这两个问题。

其中一个是把 token、timestamp、nonce三个参数进行字典序排序,当时想自己写一个方法,写了好久发现有点难受,所以在网上找了一些东西,发现那个 数组的sort方法不传递参数就是那个 默认字符编码排序,所以就非常简单了,加密直接用到crypto模块

另外一个就是微信都没有告诉我们要把那个echostr返回出去,虽然他的意思就是那个意思。。 这样就可以配置成功了。

如果你同样遇到了这个问题,看了我的文章解决了,我会非常高兴。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
Jquery 获取表单text,areatext,radio,checkbox,select值的代码
Nov 12 Javascript
jQuery温习篇 强大的JQuery选择器
Apr 24 Javascript
JavaScript 模块化编程(笔记)
Apr 08 Javascript
javascript字符串与数组转换汇总
May 26 Javascript
基于JavaScript短信验证码如何实现
Jan 24 Javascript
深入浅析AngularJS和DataModel
Feb 16 Javascript
基于jquery插件编写countdown计时器
Jun 12 Javascript
JS判断form内所有表单是否为空的简单实例
Sep 09 Javascript
angularJs使用ng-repeat遍历后选中某一个的方法
Sep 30 Javascript
js面向对象之实现淘宝放大镜
Jan 15 Javascript
Vue事件处理原理及过程详解
Mar 11 Javascript
vue-element-admin项目导入和导出的实现
May 21 Vue.js
vue实现购物车抛物线小球动画效果的方法详解
Feb 13 #Javascript
Jquery实现无缝向上循环滚动列表的特效
Feb 13 #jQuery
vuex实现的简单购物车功能示例
Feb 13 #Javascript
jquery无缝图片轮播组件封装
Nov 25 #jQuery
Vue中多个元素、组件的过渡及列表过渡的方法示例
Feb 13 #Javascript
vue写h5页面的方法总结
Feb 12 #Javascript
如何将百度地图包装成Vue的组件的方法步骤
Feb 12 #Javascript
You might like
PHP.MVC的模板标签系统(四)
2006/09/05 PHP
php is_executable判断给定文件名是否可执行实例
2016/09/26 PHP
jQuery Flash/MP3/Video多媒体插件
2010/01/18 Javascript
通过javascript的匿名函数来分析几段简单有趣的代码
2010/06/29 Javascript
基于JavaScript实现瀑布流效果(循环渐近)
2016/01/27 Javascript
Bootstrap3制作自己的导航栏
2016/05/12 Javascript
jQuery实用小技巧_输入框文字获取和失去焦点的简单实例
2016/08/25 Javascript
H5基于iScroll实现下拉刷新和上拉加载更多
2017/07/18 Javascript
jQuery实现的简单图片轮播效果完整示例
2018/02/08 jQuery
JavaScript常用工具方法封装
2019/02/12 Javascript
微信小程序开发注意指南和优化实践(小结)
2019/06/21 Javascript
nodejs对项目下所有空文件夹创建gitkeep的方法
2019/08/02 NodeJs
JavaScript对象属性操作实例解析
2020/02/04 Javascript
JavaScript实现横版菜单栏
2020/03/17 Javascript
js实现简易ATM功能
2020/10/27 Javascript
Ant Design Pro 之 ProTable使用操作
2020/10/31 Javascript
[01:05:12]2014 DOTA2国际邀请赛中国区预选赛 TongFu VS CIS-GAME
2014/05/21 DOTA
Python网络爬虫中的同步与异步示例详解
2018/02/03 Python
Python使用try except处理程序异常的三种常用方法分析
2018/09/05 Python
对numpy中二进制格式的数据存储与读取方法详解
2018/11/01 Python
python numpy之np.random的随机数函数使用介绍
2019/10/06 Python
Python求正态分布曲线下面积实例
2019/11/20 Python
Python3 A*寻路算法实现方式
2019/12/24 Python
python批量修改xml属性的实现方式
2020/03/05 Python
使用py-spy解决scrapy卡死的问题方法
2020/09/29 Python
Bootstrap File Input文件上传组件
2020/12/01 HTML / CSS
与C++相比,Java中的数组有什么不同
2014/03/25 面试题
好军嫂事迹材料
2014/01/15 职场文书
公司拓展活动方案
2014/02/13 职场文书
委托书怎样写
2014/08/30 职场文书
2015年监理工作总结范文
2015/04/07 职场文书
本科毕业论文致谢词
2015/05/14 职场文书
教师岗位说明书
2015/09/30 职场文书
如何制定一份可行的计划!
2019/06/21 职场文书
2019开业庆典剪彩仪式主持词!
2019/07/22 职场文书
创业计划书之青年旅馆
2019/09/23 职场文书