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 相关文章推荐
javascript与cookie 的问题详解
Nov 11 Javascript
jQuery简单图表peity.js使用示例
May 02 Javascript
jQuery如何将选中的对象转化为原始的DOM对象
Jun 09 Javascript
JavaScript编码风格指南(中文版)
Aug 26 Javascript
Bootstrap CSS组件之分页(pagination)和翻页(pager)
Dec 17 Javascript
JavaScript数据结构之二叉树的遍历算法示例
Apr 13 Javascript
Javascript实现页面滚动时导航智能定位
May 06 Javascript
js数字滑动时钟的简单实现(示例讲解)
Aug 14 Javascript
微信小程序项目实践之主页tab选项实现
Jul 18 Javascript
Angular之jwt令牌身份验证的实现
Feb 14 Javascript
Vue.js 中制作自定义选择组件的代码附演示demo
Feb 28 Javascript
js实现小星星游戏
Mar 23 Javascript
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
Discuz板块横排显示图片的实现方法
2007/05/28 PHP
ThinkPHP 连接Oracle数据库的详细教程[全]
2012/07/16 PHP
eaglephp使用微信api接口开发微信框架
2014/01/09 PHP
php字符集转换
2017/01/23 PHP
JSON为什么那样红为什么要用json(另有洞天)
2012/12/26 Javascript
可简单避免的三个JS发布错误的详细介绍
2013/08/02 Javascript
JavaScript获取客户端计算机硬件及系统等信息的方法
2014/01/02 Javascript
JavaScript获取元素尺寸和大小操作总结
2015/02/27 Javascript
基于javascript实现根据身份证号码识别性别和年龄
2016/01/22 Javascript
用jQuery实现可输入多选下拉组合框实例代码
2017/01/18 Javascript
使用原生js写ajax实例(推荐)
2017/05/31 Javascript
javascript cookie的基本操作(添加和删除)
2017/07/24 Javascript
详解在Vue中使用TypeScript的一些思考(实践)
2018/07/06 Javascript
jQuery实现网页拼图游戏
2020/04/22 jQuery
JavaScript基础之静态方法和实例方法分析
2018/12/26 Javascript
Vue实现仿iPhone悬浮球的示例代码
2020/03/13 Javascript
详解如何在vue+element-ui的项目中封装dialog组件
2020/12/11 Vue.js
[01:03]悬念揭晓 11月26日DOTA2完美盛典不见不散
2017/11/23 DOTA
python实现的简单FTP上传下载文件实例
2015/06/30 Python
Python argv用法详解
2016/01/08 Python
python 从文件夹抽取图片另存的方法
2018/12/04 Python
python 执行文件时额外参数获取的实例
2018/12/18 Python
Atom Python 配置Python3 解释器的方法
2019/08/28 Python
Python协程 yield与协程greenlet简单用法示例
2019/11/22 Python
Jupyter notebook设置背景主题,字体大小及自动补全代码的操作
2020/04/13 Python
基于python实现查询ip地址来源
2020/06/02 Python
PyTorch安装与基本使用详解
2020/08/31 Python
CSS3绘制不规则图形的一些方法示例
2015/11/07 HTML / CSS
深入解析HTML5中的Blob对象的使用
2015/09/08 HTML / CSS
美国传奇滑手Paul Rodriguez创办的街头滑板品牌:Primitive Skateboarding
2019/10/29 全球购物
经典c++面试题六
2012/01/18 面试题
化妆品店促销方案
2014/02/24 职场文书
和解协议书
2014/04/16 职场文书
毕业生学校推荐信范文
2014/05/21 职场文书
个人批评与自我批评
2014/10/15 职场文书
2014年护士长工作总结
2014/11/11 职场文书