NestJS入门6:日志中间件

前文参考:

NestJS入门1

NestJS入门2:创建模块

NestJS入门3:不同请求方式前后端写法

NestJS入门4:MySQL typeorm 增删改查

NestJS入门5:加入Swagger

1. 安装

bash 复制代码
nest g middleware logger middleware

2. logger.middleware.ts修改

logger.middleware.ts修改为:

TypeScript 复制代码
import { Injectable, NestMiddleware } from '@nestjs/common';
import { Request, Response } from 'express';

@Injectable()
export class LoggerMiddleware implements NestMiddleware {
  use(req: Request, res: Response, next: () => void) {
    const {method, path} = req;
    console.log(`${method} ${path}`);
    next();
  }
}

3. app.modules.ts修改

app.modules.ts修改为:

TypeScript 复制代码
import { Module } from '@nestjs/common';
import { AppController } from './app.controller';
import { AppService } from './app.service';
import { UserModule } from "./user/user.module";
import { TypeOrmModule } from "@nestjs/typeorm";
import { LoggerMiddleware } from './middleware/logger/logger.middleware';
import { MiddlewareBuilder } from '@nestjs/core';

@Module({
  imports: [UserModule,
    TypeOrmModule.forRoot({
      type: "mysql",
      host: "localhost",
      port: 3306,
      username: "root",
      password: "root",
      database: "user", //数据库名称
      entities: ["dist/**/*.entity{.ts,.js}"], //扫描本项目中.entity.ts或者.entity.js的文件
      synchronize: true,
    }),],
  controllers: [AppController],
  providers: [AppService],
})
export class AppModule {
  configure(consumer: MiddlewareBuilder){

    consumer.apply(LoggerMiddleware).forRoutes('user');
  }



}

可改为星号通配符,表示任意路由

TypeScript 复制代码
consumer.apply(LoggerMiddleware).forRoutes('*');

4. 测试

使用postman或swagger测试,后端可以看到请求方法与路径的打印

相关推荐
前端付豪3 小时前
必知 Express和 MVC
前端·node.js·全栈
特别橙的橙汁3 小时前
Node.js 调用可执行文件时的 stdout 缓冲区问题
前端·node.js·swift
alamhubb4 小时前
反感pnpm的全链路污染?可以了解下这个对原项目零侵入,零修改完全兼容npm的monorepo工具
前端·javascript·node.js
Wang's Blog5 小时前
Nodejs-HardCore: 流类型、应用与内置类型实战
nodejs
程序员agions7 小时前
Node.js 爬虫实战指南(三):分布式爬虫架构,让你的爬虫飞起来
分布式·爬虫·node.js
鲨莎分不晴7 小时前
PM2 是什么?一篇讲清 Node.js 进程管理器的文章
node.js
程序员agions8 小时前
Node.js 爬虫实战指南(四):反反爬策略大全,和网站斗智斗勇
爬虫·node.js
程序员爱钓鱼9 小时前
Node.js 编程实战:博客系统 —— 数据库设计
前端·后端·node.js
程序员agions9 小时前
Node.js 爬虫实战指南(二):动态页面爬取,Puppeteer 大显身手
爬虫·node.js
Wang's Blog11 小时前
Nodejs-HardCore: 玩转 EventEmitter 指南
开发语言·nodejs