一、在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
}
}
}