在提交配置时,服务器对应的URL需要实现签名的验证,成功时,需要直接返回 echostr 的值,注意此时URL对应的接口为get请求
const { signature, timestamp, nonce, echostr } = _req.query;
const token = "my_token"; // 公众号配置时的Token
const tmpArr = [token, timestamp, nonce];
tmpArr.sort();
// 引入加密模块
const crypto = require('crypto');
// 创建哈希对象
const sha1Hash = crypto.createHash('sha1');
// console.log("排序后连接:", tmpArr.join(""))
sha1Hash.update(tmpArr.join(""));
const hashedData = sha1Hash.digest('hex');
// console.log(hashedData, signature);
if (hashedData == signature) {
res.end(echostr);
}
在用户操作时(关注、取消关注、扫描公众号二维码码等操作时),微信公众号会发送消息到基本配置中的URL对应的接口,注意此时URL对应的接口为post请求,也就是说URL对应的接口需要同时支持get和post请求。而且需要在IP白名单中添加服务器的IP地址。
// router.js
varapi = require('./api'