在 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中的状况加密