一、NestJS中使用中间件
1、官网地址:
NestJS 中文网Nest 是一个用于构建高效、可扩展的 Node.js 服务器端应用程序的框架。 它使用渐进式 JavaScript,使用 TypeScript 构建,并结合了 OOP(面向对象编程)、FP(函数式编程)和 FRP(函数式反应式编程)的元素。https://nest.nodejs.cn/middleware2、写了一个Logger中间件,主要是要记录请求记录,之前练习的时候做了这个功能,请求过来记录到数据库,由于我新建的项目还没创建这部分表,后面会再补充
import { Injectable, NestMiddleware } from '@nestjs/common';
import { Request, Response, NextFunction } from 'express';
// import { Syslog } from 'src/syslogs/entities/syslog.entity';
// import { SyslogsService } from 'src/syslogs/syslogs.service';
// import * as useragent from 'express-useragent';
@Injectable()
export class LoggerMiddleware implements NestMiddleware {
// constructor(private readonly syslogsService: SyslogsService) {}
use(req: Request, res: Response, next: NextFunction) {
//请求记录入库
// throw new Error('Method not implemented.');
// let ua = useragent.parse(req.headers['user-agent'])
// const log = new Syslog()
// log.ip = req.ip
// log.browser = ua.browser
// log.os = ua.os
// log.source = ua.source
// log.account = ''
// log.route = req.baseUrl
// log.origin = req.headers['origin'] === undefined ? '' : req.headers['origin']
// log.method = req.method
// log.host = req.hostname
// if (Object.keys(req.body).length != 0)
// log.params = JSON.stringify(req.body)
// else if (Object.keys(req.query).length != 0)
// lo