nest.js-学习记录:8、使用class-validator验证请求数据

一、在main.ts

import { NestFactory } from '@nestjs/core';
import { SwaggerModule, DocumentBuilder } from '@nestjs/swagger';
import { AppModule } from './app.module';
import { ValidationPipe } from '@nestjs/common';//新加
// 导入mongoose
import * as mongoose from 'mongoose'
declare const module: any;

async function bootstrap() {
  mongoose.connect('mongodb://localhost:27017/nest-blog-api')

  const app = await NestFactory.create(AppModule); 
 // 验证管道
  app.useGlobalPipes(new ValidationPipe)//新加

  const config = new DocumentBuilder()
    // 标题
    .setTitle('NestJs博客API') 
    // 描述
    .setDescription('我的第一个NestJs项目') 
    // 版本
    .setVersion('1.0')
    .build();
  // 引入Swagger
  const document = SwaggerModule.createDocument(app, config);
  // 接口文档路径
  SwaggerModule.setup('api-docs', app, document); 
  // 监听端口号3000
  await app.listen(3000); 
   
  if (module.hot) {
    module.hot.accept();
    module.hot.dispose(() => app.close());
  }
}

bootstrap();

二、执行npm i --save class-validator class-transformer下载
三、使用

import { Body, Controller, Delete, Get, Param, Post, Put, Query } from '@nestjs/common';
import { ApiOperation, ApiProperty, ApiTags } from '@nestjs/swagger';
import { PostModel } from './posts.model';
// 引入验证
import { IsNotEmpty } from "class-validator"//新加
// 标识创建帖子的参数详情
class createPostDto{
    @ApiProperty({description:'帖子标题'})
    // 验证-不能为空
    @IsNotEmpty({message:'请填写标题'})//新加
    title:string
    @ApiProperty({description:'帖子内容'})
     // 验证-不能为空
    @IsNotEmpty({message:'请填写标题'})//新加 message表示不符合时的提示。
    content:string
}

@Controller('posts')
@ApiTags('帖子')
export class PostsController {
  @Get()
  @ApiOperation({summary:'显示帖子列表'})
 async index() {
    return await PostModel.find()
  }

  @Post()
  @ApiOperation({summary:"创建帖子"})
  // 获取post请求的数据用@Body()装饰器获取数据,get用@query()
 async create(@Body() Body:createPostDto){
    await PostModel.create(Body)
    return{
      success:true
    }
  }

  @Get(':id')
  @ApiOperation({summary:"帖子详情"})
  async detail(@Param('id') id:string){
    return await PostModel.findById(id)
  }

  @Put(':id')
  @ApiOperation({summary:'编辑帖子详情'})
  async update(@Param('id') id:string,@Body() body:createPostDto){
    await PostModel.findByIdAndUpdate(id,body)
    return {
      success:true
    }
  }
  @Delete(':id')
  @ApiOperation({summary:'删除帖子'})
  async remove(@Param('id') id:string){
    await PostModel.findByIdAndDelete(id)
    return{
      success:true
    }

  }
}
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

言只 石皮

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值