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的属性选择符和自定义选择符使用方法(二)
Apr 07 Javascript
jquery iframe操作详细解析
Nov 20 Javascript
用JQuery实现全选与取消的两种简单方法
Feb 22 Javascript
JavaScript模拟重力状态下抛物运动的方法
Mar 03 Javascript
JS实现简单路由器功能的方法
May 27 Javascript
js实现四舍五入完全保留两位小数的方法
Aug 02 Javascript
基于vuejs+webpack的日期选择插件
May 21 Javascript
VueJs路由跳转——vue-router的使用详解
Jan 10 Javascript
Vuejs 组件——props数据传递的实例代码
Mar 07 Javascript
canvas实现环形进度条效果
Mar 23 Javascript
javascript防篡改对象实例详解
Apr 10 Javascript
vue移动端UI框架实现QQ侧边菜单组件
Mar 09 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
php语言流程控制中的主动与被动
2012/11/05 PHP
『PHP』PHP截断函数mb_substr()使用介绍
2013/04/22 PHP
PHP 通过Socket收发十六进制数据的实现代码
2013/08/16 PHP
Mac OS下配置PHP+MySql环境
2015/02/25 PHP
实现PHP中session存储及删除变量
2018/10/15 PHP
javascript 简单抽屉效果的实现代码
2010/03/09 Javascript
Eval and new funciton not the same thing
2012/12/27 Javascript
jquery实现的仿天猫侧导航tab切换效果
2015/08/24 Javascript
jquery实现清新实用的网页菜单效果
2015/08/28 Javascript
JS判断iframe是否加载完成的方法
2016/08/03 Javascript
jQuery实现ajax的叠加和停止(终止ajax请求)
2016/08/08 Javascript
jquery.Callbacks的实现详解
2016/11/30 Javascript
解决vue2.0路由跳转未匹配相应用路由避免出现空白页面的问题
2018/08/24 Javascript
vue自定义正在加载动画的例子
2019/11/14 Javascript
vue实现动态表格提交参数动态生成控件的操作
2020/11/09 Javascript
[00:53]2015国际邀请赛 中国区预选赛一触即发
2015/05/14 DOTA
跟老齐学Python之模块的加载
2014/10/24 Python
常见python正则用法的简单实例
2016/06/21 Python
python读取一个目录下所有txt里面的内容方法
2018/06/23 Python
python Flask 装饰器顺序问题解决
2018/08/08 Python
Python笔记之工厂模式
2019/11/20 Python
Python 如何批量更新已安装的库
2020/05/26 Python
浅谈html5与APP混合开发遇到的问题总结
2018/03/20 HTML / CSS
html5利用canvas实现颜色容差抠图功能
2019/12/23 HTML / CSS
英国翻新电子产品购物网站:Tech Trade
2017/12/25 全球购物
美国宠物美容和宠物用品购物网站:Cherrybrook
2018/12/07 全球购物
荷兰家电购物网站:Expert.nl
2020/01/18 全球购物
毕业生教师求职信
2013/10/20 职场文书
国际贸易毕业生自荐书
2014/06/22 职场文书
对照四风自我剖析材料
2014/10/07 职场文书
2014年助理工程师工作总结
2014/11/14 职场文书
2014年房地产销售工作总结
2014/12/01 职场文书
房地产公司工程部经理岗位职责
2015/04/09 职场文书
vue中三级导航的菜单权限控制
2021/03/31 Vue.js
MongoDB数据库常用的10条操作命令
2021/06/18 MongoDB
python3操作redis实现List列表实例
2021/08/04 Python