nodejs的express使用全局拦截器保存用户请求和响应日志
前言:为了记录用户的请求记录,想要记录用户的ip,请求入参,请求方法,以及返回内容,我使用中间件收集用户请求数据保存到数据库
1.数据库表结构
CREATE TABLE `admin_request_log` (
`id` int(11) unsigned NOT NULL AUTO_INCREMENT COMMENT '主键',
`user_id` int(11) DEFAULT NULL COMMENT '用户id',
`url` varchar(1000) DEFAULT NULL COMMENT '请求地址',
`method` varchar(10) DEFAULT NULL COMMENT '请求方式',
`body` text COMMENT '请求body',
`params` varchar(1000) DEFAULT NULL COMMENT '请求params',
`ip_address` varchar(100) DEFAULT NULL COMMENT 'ip地址',
`result` text COMMENT '响应内容',
`created_time` datetime DEFAULT NULL COMMENT '创建时间',
`updated_time` datetime DEFAULT NULL ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=89 DEFAULT CHARSET=utf8mb4;
2.日志拦截器的方法
// 全局日志拦截器
const endMiddleware = (req, res, next) => {
const defaultWrite = res.write;
const defaultEnd = res.end;
const chunks = [];
res.write = (...restArgs) => {
chunks.push(Buffer.from(restArgs[0]));
defaultWrite.apply(res, restArgs);
};
res.end = (...restArgs) => {
let mList = ["POST","GET"]
if(mList.indexOf(req.method) !== -1){
if (restArgs[0]) {
chunks.push(Buffer.from(restArgs[0]));
}
const body = Buffer.concat(chunks).toString('utf8');
const time = moment(new Date()).format("YYYY-MM-DD HH:mm:ss");
AdminRequestLog.create({
user_id: (req.data && req.data.user_id) ? req.data.user_id : null,
url:req.url,
method: req.method,
body: JSON.stringify(req.body),
params: "",
ip_address: getClientIp(req),
result: JSON.stringify(body),
create_time: time,
updated_time: time,
});
}
defaultEnd.apply(res, restArgs);
};
next();
};
app.use(endMiddleware)
使用的是res.end方法等待方法返回,然后将返回数据解析出来保存到数据库
3.缺省方法说明
(1)AdminRequestLog 这个是使用的数据库orm框架sequelize模型插入数据
(2)getClientIp 这和是获取用户ip的方法,如下:
//函数返回ip地址
function getClientIp(req) {
return req.headers['x-forwarded-for'] ||
req.connection.remoteAddress ||
req.socket.remoteAddress ||
req.connection.socket.remoteAddress;
}
4.最终效果
这篇好文章是转载于:学新通技术网
- 版权申明: 本站部分内容来自互联网,仅供学习及演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,请提供相关证据及您的身份证明,我们将在收到邮件后48小时内删除。
- 本站站名: 学新通技术网
- 本文地址: /boutique/detail/tanhgeafke
系列文章
更多
同类精品
更多
-
photoshop保存的图片太大微信发不了怎么办
PHP中文网 06-15 -
Android 11 保存文件到外部存储,并分享文件
Luke 10-12 -
《学习通》视频自动暂停处理方法
HelloWorld317 07-05 -
word里面弄一个表格后上面的标题会跑到下面怎么办
PHP中文网 06-20 -
photoshop扩展功能面板显示灰色怎么办
PHP中文网 06-14 -
微信公众号没有声音提示怎么办
PHP中文网 03-31 -
excel下划线不显示怎么办
PHP中文网 06-23 -
怎样阻止微信小程序自动打开
PHP中文网 06-13 -
excel打印预览压线压字怎么办
PHP中文网 06-22 -
TikTok加速器哪个好免费的TK加速器推荐
TK小达人 10-01