koa 微信开发 (1) -- 接入指南

申请公众号

mp.weixin.qq.com 上根据步骤申请一个帐号node

图片描述

进入公众号

选择开发--基本配置,进行修改配置浏览器

图片描述

服务器编写

根据文档,咱们须要作的是服务器

接入微信公众平台开发,开发者须要按照以下步骤完成:
一、填写服务器配置
二、验证服务器地址的有效性
三、依据接口文档实现业务逻辑

当你在配置中写完配置,要提交的时候,微信会对你填写的url发送一个get请求, 包括:微信

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

服务器配置以下:微信公众平台

router.get('/wechat', function *() {
        // 获取微信的请求,注意是 get
        var signature = this.query.signature;
        var echostr = this.query.echostr;
        var timestamp = this.query.timestamp;
        var nonce = this.query.nonce;
        
        // 这里的token 要和你表单上面的token一致
        var token = 'MMDBB';
        
        // 根文档上面的,咱们须要对这三个参数进行字典序排序
        var arr = [token, timestamp, nonce];
        arr.sort();
        var tmpStr = arr.join('');
        
        // 排序完成以后,须要进行sha1加密, 这里咱们使用node.js 自带的crypto模块
        var sha1 = crypto.createHash('sha1');
        sha1.update(tmpStr);
        var resStr = sha1.digest('hex');
        console.log(signature, 'resStr: ', resStr);
        
        // 开发者得到加密后的字符串可与signature对比,标识该请求来源于微信,
        // 若是匹配,返回echoster , 不匹配则返回error
        if (resStr === signature) {
            this.body = echostr;
        } else {
          return false;
        }
    });

须要注意的点:

  • url 的端口必须是80 或者 443this

  • 若是验证失败,能够在浏览器的开发者模式下,查看network中的状况加密

相关文章
相关标签/搜索