Nest.js项目小结1

2024-04-25 05:12
文章标签 项目 js 小结 nest

本文主要是介绍Nest.js项目小结1,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

整体项目结构

        prisma\        (用于管理数据库迁移、定义数据模型和数据填充)

                migrations\        (日志记录,不用管)

                schema.prisma        (定义数据模型)

                seed.ts        (用于填充数据库初始数据的文件)

        src\

                auth\        (包含处理用户认证的模块代码)

                        dto\        (定义数据传输对象)

                                register.dto.ts        (数据对象)

                        auth.controller.ts         (处理路由等)

                        auth.module.ts            (模块)

                        auth.service.ts            (逻辑)

                common\        (包含通用的功能代码)

                        rules\        (自定义验证规则)

                                is-confirm.rule.ts

                                is-not-exists.rule.ts

                        validate.ts        (通用数据验证)

                prisma\

                        prisma.module.ts        (模块)

                        prisma.service.ts        (处理与Prisma数据库交互的服务)

                app.module.ts        (模块)

                main.ts        (主入口)

                transform.inteceptor.ts        (响应拦截器)

——————————————————————————————————————

schema.prisma       

        定义数据库模型

generator client {provider = "prisma-client-js"
}datasource db {provider = "mysql"url      = env("DATABASE_URL")
}model user {id       Int     @id @default(autoincrement()) @db.UnsignedIntname     String  @uniquepassword String
}model article {id       Int     @id @default(autoincrement()) @db.UnsignedInttitle    Stringcontent  String  @db.Text
}

seed.ts

        填充数据库数据

import { PrismaClient } from "@prisma/client"
import { hash } from "argon2"
import { Random } from "mockjs"const prisma = new PrismaClient()    //注册Prisma
async function run() {await prisma.user.create({    //往user表里面插入数据data: {name: "admin",password: await hash("admin8888")    //转成hash}})for (let i = 0; i < 50; i++) {    //填充50组await prisma.article.create({    //往article表里面插入数据data: {title: Random.ctitle(10, 30),    //随机题目content: Random.cparagraph(10, 20),    //随机内容}})}}
run()

——————————————————————————————————————

app.module.ts

import { Module } from '@nestjs/common';
import { AuthModule } from './auth/auth.module';    //引入验证模块
import { PrismaModule } from './prisma/prisma.module';    //引入prisma模块@Module({imports: [ AuthModule , PrismaModule ],    //插入
})
export class AppModule {}

——————————————————————————————————————

auth

        dto

                register.dto.ts

import { IsNotEmpty } from "class-validator";    //引入默认不为空验证
import { IsNotExistsRule } from "../../common/rules/is-not-exists.rule"; //引入自定义验证
import { IsConfiemRule } from "../../common/rules/is-confirm.rule";    //引入自定义验证export default class RegisterDto {    @IsNotEmpty({ message:'用户名不能为空' })                //验证规则@IsNotExistsRule("user" , { message: "用户已经存在" })   //验证规则name:string;                                             //类型@IsNotEmpty({ message:'密码不能为空' })@IsConfiemRule({ message: "两次密码不一致" })password:string@IsNotEmpty({message: "确认密码不能为空"})password_confirm: string
}

auth.controller.ts

import { Controller , Body , Post } from '@nestjs/common'
import { AuthService } from './auth.service';
import RegisterDto from './dto/register.dto';    //引入验证规则@Controller()
export class AuthController{constructor(private auth: AuthService) {}@Post('register')    //post请求,路由为registerlogin(@Body() dto: RegisterDto) {    //获取body数据 为dto : 验证规则return this.auth.register(dto)    //执行auth的register函数}
}

auth.service.ts

import { Injectable } from '@nestjs/common'
import RegisterDto from './dto/register.dto';
import { PrismaService } from './../prisma/prisma.service';    //引入全局配置prisma
import { hash } from 'argon2';
import { JwtService } from '@nestjs/jwt';@Injectable()
export class AuthService {constructor(private prisma:PrismaService , private jwt: JwtService){}async register(dto: RegisterDto){    //验证通过后执行这里const user = await this.prisma.user.create({    //等候创建data:{name: dto.name,password: await hash(dto.password)}})return this.token(user);    //执行token函数}private async token({ id , name }){return {token: await this.jwt.signAsync({ //执行配置好后的jwtname , sub: id })}}
}

auth.module.ts

import { Module } from '@nestjs/common'
import { AuthService } from './auth.service'
import { AuthController } from './auth.controller'
import { JwtModule } from '@nestjs/jwt'
import { ConfigModule, ConfigService } from '@nestjs/config'@Module({imports: [        //TODO        配置JWTJwtModule.registerAsync({imports: [ConfigModule],inject: [ConfigService],useFactory: (config: ConfigService) => {return {secret: config.get('TOKEN_SECRET'),    //密钥在.env里配置signOptions: { expiresIn: '60d' }    //持续时间}},})],        //ENDcontrollers: [AuthController],    //引入控制器providers: [AuthService]    //引入函数
})export class AuthModule{}

common

        rules

                is-confirm.rule.ts

import { PrismaClient } from '@prisma/client'
import { registerDecorator , ValidationArguments , ValidationOptions } from 'class-validator'//表字段是否唯一
export function IsConfiemRule(    //这里定义规则名称validationOptions?: ValidationOptions
) {return function (object: Record<string , any>, propertyName: string) {registerDecorator({name: 'IsConfiemRule',    //同上target: object.constructor,propertyName: propertyName,constraints: [],options: validationOptions,validator: {async validate(value: string, args: ValidationArguments) {//TODOreturn Boolean(value == args.object[`${args.property}_confirm`]) //true为通过,false为不通过//END}}})}
}

                is-not-exists.ule.ts

import { PrismaClient } from '@prisma/client'
import { registerDecorator , ValidationArguments , ValidationOptions } from 'class-validator'//表字段是否唯一
export function IsNotExistsRule(table: string,validationOptions?: ValidationOptions
) {return function (object: Record<string , any>, propertyName: string) {registerDecorator({name: 'IsNotExistsRule',target: object.constructor,propertyName: propertyName,constraints: [table],options: validationOptions,validator: {async validate(value: string, args: ValidationArguments) {//TODOconst prisma = new PrismaClientconst res = await prisma[table].findFirst({where: {[args.property]: value}})return !Boolean(res)//END}}})}
}
//同上

        validate.ts

import { HttpException, HttpStatus, ValidationPipe } from "@nestjs/common";
import { ValidationError } from "class-validator";export default class Validate extends ValidationPipe {protected flattenValidationErrors(validationErrors: ValidationError[]): string[] {const messages = {}validationErrors.forEach(error => {    //遍历出必要错误返回给前端messages[error.property] = Object.values(error.constraints)[0];})throw new HttpException({    //返回给前端的错误code: 422,    messages}, HttpStatus.UNPROCESSABLE_ENTITY); }
}

prisma

        prisma.module.ts

import { Global, Module } from '@nestjs/common'
import { PrismaService } from './prisma.service';@Global() // 全局模块
@Module({providers: [PrismaService],exports: [PrismaService]
})export class PrismaModule{}

        prisma.service.ts

import { PrismaClient } from '@prisma/client' 
import { Injectable } from '@nestjs/common'@Injectable()
export class PrismaService extends PrismaClient{constructor(){super({log:['query']})}
}

transform.inteceptor.ts

import { CallHandler , ExecutionContext , Injectable , NestInterceptor } from '@nestjs/common'
import { map } from 'rxjs/operators'@Injectable()
export class TransformInterceptor implements NestInterceptor {    //修改一下数据格式intercept(context: ExecutionContext, next: CallHandler) {return next.handle().pipe(map((data) => {return {data}}))}
}

main.ts

import { NestFactory } from '@nestjs/core';
import { AppModule } from './app.module';
import Validate from './common/validate';
import { TransformInterceptor } from './transform.inteceptor';async function bootstrap() {const app = await NestFactory.create(AppModule);app.useGlobalPipes(new Validate())    //返回给前端的错误数据app.useGlobalInterceptors(new TransformInterceptor())    //返回给前端的正确数据(响应拦截器)await app.listen(3000);    //监听的端口号
}
bootstrap();

这篇关于Nest.js项目小结1的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/933774

相关文章

深度解析Java项目中包和包之间的联系

《深度解析Java项目中包和包之间的联系》文章浏览阅读850次,点赞13次,收藏8次。本文详细介绍了Java分层架构中的几个关键包:DTO、Controller、Service和Mapper。_jav... 目录前言一、各大包1.DTO1.1、DTO的核心用途1.2. DTO与实体类(Entity)的区别1

如何在Spring Boot项目中集成MQTT协议

《如何在SpringBoot项目中集成MQTT协议》本文介绍在SpringBoot中集成MQTT的步骤,包括安装Broker、添加EclipsePaho依赖、配置连接参数、实现消息发布订阅、测试接口... 目录1. 准备工作2. 引入依赖3. 配置MQTT连接4. 创建MQTT配置类5. 实现消息发布与订阅

springboot项目打jar制作成镜像并指定配置文件位置方式

《springboot项目打jar制作成镜像并指定配置文件位置方式》:本文主要介绍springboot项目打jar制作成镜像并指定配置文件位置方式,具有很好的参考价值,希望对大家有所帮助,如有错误... 目录一、上传jar到服务器二、编写dockerfile三、新建对应配置文件所存放的数据卷目录四、将配置文

怎么用idea创建一个SpringBoot项目

《怎么用idea创建一个SpringBoot项目》本文介绍了在IDEA中创建SpringBoot项目的步骤,包括环境准备(JDK1.8+、Maven3.2.5+)、使用SpringInitializr... 目录如何在idea中创建一个SpringBoot项目环境准备1.1打开IDEA,点击New新建一个项

Redis分片集群、数据读写规则问题小结

《Redis分片集群、数据读写规则问题小结》本文介绍了Redis分片集群的原理,通过数据分片和哈希槽机制解决单机内存限制与写瓶颈问题,实现分布式存储和高并发处理,但存在通信开销大、维护复杂及对事务支持... 目录一、分片集群解android决的问题二、分片集群图解 分片集群特征如何解决的上述问题?(与哨兵模

SpringBoot中使用Flux实现流式返回的方法小结

《SpringBoot中使用Flux实现流式返回的方法小结》文章介绍流式返回(StreamingResponse)在SpringBoot中通过Flux实现,优势包括提升用户体验、降低内存消耗、支持长连... 目录背景流式返回的核心概念与优势1. 提升用户体验2. 降低内存消耗3. 支持长连接与实时通信在Sp

Python打印对象所有属性和值的方法小结

《Python打印对象所有属性和值的方法小结》在Python开发过程中,调试代码时经常需要查看对象的当前状态,也就是对象的所有属性和对应的值,然而,Python并没有像PHP的print_r那样直接提... 目录python中打印对象所有属性和值的方法实现步骤1. 使用vars()和pprint()2. 使

HTML5 getUserMedia API网页录音实现指南示例小结

《HTML5getUserMediaAPI网页录音实现指南示例小结》本教程将指导你如何利用这一API,结合WebAudioAPI,实现网页录音功能,从获取音频流到处理和保存录音,整个过程将逐步... 目录1. html5 getUserMedia API简介1.1 API概念与历史1.2 功能与优势1.3

springboot项目中整合高德地图的实践

《springboot项目中整合高德地图的实践》:本文主要介绍springboot项目中整合高德地图的实践,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一:高德开放平台的使用二:创建数据库(我是用的是mysql)三:Springboot所需的依赖(根据你的需求再

一文详解如何在idea中快速搭建一个Spring Boot项目

《一文详解如何在idea中快速搭建一个SpringBoot项目》IntelliJIDEA作为Java开发者的‌首选IDE‌,深度集成SpringBoot支持,可一键生成项目骨架、智能配置依赖,这篇文... 目录前言1、创建项目名称2、勾选需要的依赖3、在setting中检查maven4、编写数据源5、开启热