NodeJs 开发微信公众号——验证服务器

常见的几种微信授权登录方式

常见的几种微信授权登录方式

最近被微信各种登录方式,整的实在是有点蒙,网页登录,公众号登录,微信小程序登录,等等虽然登录的方式大体上差不多,但不同的地方差别还是很大的,只能等到我不是太晕了,然后过来整理下文章,找找错误。。。
2019年12月22日22:21:48

2020年2月18日00点01分
弄懂 oAuth2.0 协议,网页登录,公众号登录,微信小程序登录、github 登录都不是问题。


微信公众号开发,微信后台开发者工具提供了六个模块,但只有四个模块比较有用:



开发文档不用讲了,在线接口调试工具就是你写接口的时候,一直报错就用接口调试工具来看看哪里写错了。web开发工具开发的微信网页在PC上运行调试,公众号测试账号就是用来辅助开发的,公众号第三方服务平台可以把公众号委托给第三方使用,CDN收费的。。。

一、开始验证服务器的有效性

为什么要验证服务器的有效性?公众号的通信方式是这样的

用户发消息=>微信服务器接收=>我们的服务器进行处理数据完成返回=>微信服务器=>用户接收

我们要保证微信服务器和我们的服务器之间通信安全。所以他俩之间有个 token,来标识对方。不会让第三方来冒充。

真实的服务器环境配置:


再开始开发公众号之前,先完成 接入指南

接入指南 针对的是真正的公众号和服务器,但是一般我们开发限于真正公众号提供的接口不全,都是使用测试号,所以下面 接入指南 主要是在测试号上演示。两者没啥区别。

第一步:填写服务器配置。主要涉及的是填写服务器地址(URL)、Token和EncodingAESKey(测试号没有)。
测试号填写地址

接口地址必须是外网能够访问的,我们没有备案可访问的域名,就用内网穿透来开发。内网穿透方式两个,两种方式都有免费的和收费的,免费的最大的不方便之处就是每次启动服务分配的域名是不同的,你的老是去改后台网址链接,收费的就没有这个烦恼,想方便点的话,买一个月的也不是很贵,我买的时候九块,买的就是 netapp的,用起来还不错:

  • netapp


    netapp穿透效果
  • ngrok 点击下载网址
    下载ngrok

    下载完成之后,即可以使用 ngrok http 3000 来启用本地的 3000 端口。启用成功截图如下:
第二步:验证消息的确来自微信服务器

开发者提交信息后,微信服务器将发送GET请求到填写的服务器地址URL上参数。

  1. 描述 signature 微信加密签名,signature结合了开发者填写的token参数和请求中的timestamp参数、nonce参数。
  2. timestamp 时间戳
  3. nonce 随机数
  4. echostr 随机字符串

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

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

检验 signature 的 NodeJS 示例代码:

const app = require("express")();

app.use((req,res)=>{
    console.log(req.query);
    res.send();
});

app.listen(80,()=>console.log("80端口号成功运行"));

启用服务器看看微信提交验证的时候到底发过来的是啥子。



接下来就要验证了消息是否来自服务器:



更改 app.js 文件内容为:
const app = require("express")();
const sha1 = require("sha1");

app.use((req,res,next)=>{
    // GET请求携带参数是个参数signature,timestamp,nonce,echostr
    const {signature,timestamp,nonce,echostr} = req.query;
    
    // 服务器的token
    const token = "TOKEN";

    // 将token、timestamp、nonce三个参数进行字典序排序 
    const arrSort = [token,timestamp,nonce];
    arrSort.sort();

    // 将三个参数字符串拼接成一个字符串进行sha1加密,npm install --save sha1
    const str = arrSort.join("");
    const shaStr = sha1(str);

    // 获得加密后的字符串可与signature对比,验证标识该请求来源于微信服务器
    if(shaStr === signature){
        // 确认此次GET请求来自微信服务器,请原样返回echostr参数内容,则接入生效
        res.send(echostr);
    }else{
        //否则接入失败。
        res.send("no");
    }
});

app.listen(80,()=>console.log("80端口号成功运行"));

再次尝试连接,添加服务器配置成功:


最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 200,176评论 5 469
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 84,190评论 2 377
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 147,232评论 0 332
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,953评论 1 272
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,879评论 5 360
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,177评论 1 277
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,626评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,295评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,436评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,365评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,414评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,096评论 3 315
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,685评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,771评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,987评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,438评论 2 346
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,032评论 2 341

推荐阅读更多精彩内容