NestJS学习记录-中间件、异常过滤器、拦截器

一、NestJS中使用中间件

1、官网地址:

NestJS 中文网Nest 是一个用于构建高效、可扩展的 Node.js 服务器端应用程序的框架。 它使用渐进式 JavaScript,使用 TypeScript 构建,并结合了 OOP(面向对象编程)、FP(函数式编程)和 FRP(函数式反应式编程)的元素。icon-default.png?t=O83Ahttps://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
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值