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 相关文章推荐
js 多浏览器分别判断代码
Apr 01 Javascript
javascript实现des解密加密全过程
Apr 03 Javascript
jQuery对象的selector属性用法实例
Dec 27 Javascript
jQuery使用slideUp方法实现控制元素缓慢收起
Mar 27 Javascript
Node.js项目中调用JavaScript的EJS模板库的方法
Mar 11 Javascript
基于datepicker定义自己的angular时间组件的示例
Mar 14 Javascript
详解微信小程序实现跑马灯效果(附完整代码)
Apr 29 Javascript
浅谈v-for 和 v-if 并用时筛选条件方法
Nov 07 Javascript
vue-resourc发起异步请求的方法
Feb 11 Javascript
vue-路由精讲 二级路由和三级路由的作用
Aug 06 Javascript
vant自定义二级菜单操作
Nov 02 Javascript
vue如何实现关闭对话框后刷新列表
Apr 08 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&&mysql)一
2006/10/09 PHP
PHP连接Access数据库的方法小结
2013/06/20 PHP
php获取目标函数执行时间示例
2014/03/04 PHP
一键生成各种尺寸Icon的php脚本(实例)
2017/02/08 PHP
PHP实现websocket通信的方法示例
2018/08/28 PHP
JavaScript入门教程(7) History历史对象
2009/01/31 Javascript
JavaScript在for循环中绑定事件解决事件参数不同的情况
2014/01/20 Javascript
JavaScript表单通过正则表达式验证电话号码
2014/03/14 Javascript
javascript中if和switch,==和===详解
2015/07/30 Javascript
AngularJS 防止页面闪烁的方法
2017/03/09 Javascript
canvas简单快速的实现知乎登录页背景效果
2017/05/08 Javascript
详解如何在Angular中快速定位DOM元素
2017/05/17 Javascript
你应该知道的几类npm依赖包管理详解
2017/10/06 Javascript
ES6中的Promise代码详解
2017/10/09 Javascript
jQuery实现侧边栏隐藏与显示的方法详解
2018/12/22 jQuery
vue在App.vue文件中监听路由变化刷新页面操作
2020/08/14 Javascript
[01:00:35]2018DOTA2亚洲邀请赛3月30日B组 EffcetVSMineski
2018/03/31 DOTA
python障碍式期权定价公式
2019/07/19 Python
详解从Django Allauth中进行登录改造小结
2019/12/18 Python
Python字典底层实现原理详解
2019/12/18 Python
django实现更改数据库某个字段以及字段段内数据
2020/03/31 Python
VSCODE配置Markdown及Markdown基础语法详解
2021/01/19 Python
用CSS3绘制三角形的简单方法
2015/07/17 HTML / CSS
Parfume Klik丹麦:香水网上商店
2018/07/10 全球购物
Boom手表官网:瑞典手表品牌,设计你的手表
2019/03/11 全球购物
SmartBuyGlasses荷兰:购买太阳镜和眼镜
2020/03/16 全球购物
以下为Windows NT 下的32 位C++程序,请计算sizeof 的值
2016/12/07 面试题
会计电算化专业个人的自我评价
2013/11/24 职场文书
市场营销求职信范文
2014/02/21 职场文书
2014社区三八妇女节活动方案
2014/03/30 职场文书
中学生社会实践活动总结
2014/07/03 职场文书
交通运输局四风问题对照检查材料思想汇报
2014/10/09 职场文书
2015初中政教处工作总结
2015/07/21 职场文书
食堂管理制度范本
2015/08/04 职场文书
分析MySQL抛出异常的几种常见解决方式
2021/05/18 MySQL
Python中time与datetime模块使用方法详解
2022/03/31 Python