• 小满nestjs(第十三章 nestjs 上传图片-静态目录)


    Nestjs 上传图片

    1.主要会用到两个包

    multer   @nestjs/platform-express nestJs自带了

    multer   @types/multer 这两个需要安装

    在upload  Module 使用MulterModule register注册存放图片的目录

    需要用到  multer 的  diskStorage 设置存放目录 extname 用来读取文件后缀 filename给文件重新命名

    1. import { Module } from '@nestjs/common';
    2. import { UploadService } from './upload.service';
    3. import { UploadController } from './upload.controller';
    4. import { MulterModule } from '@nestjs/platform-express'
    5. import {diskStorage} from 'multer'
    6. import { extname,join } from 'path';
    7. @Module({
    8. imports: [MulterModule.register({
    9. storage:diskStorage({
    10. destination:join(__dirname,"../images"),
    11. filename:(_,file,callback) => {
    12. const fileName = `${new Date().getTime() + extname(file.originalname)}`
    13. return callback(null,fileName)
    14. }
    15. })
    16. })],
    17. controllers: [UploadController],
    18. providers: [UploadService]
    19. })
    20. export class UploadModule { }

    2.controller 使用

    使用 UseInterceptors 装饰器  FileInterceptor是单个 读取字段名称  FilesInterceptor是多个

    参数 使用 UploadedFile 装饰器接受file 文件

    1. import { Controller, Get, Post, Body, Patch, Param, Delete,UseInterceptors,UploadedFile } from '@nestjs/common';
    2. import { UploadService } from './upload.service';
    3. import {FileInterceptor} from '@nestjs/platform-express'
    4. @Controller('upload')
    5. export class UploadController {
    6. constructor(private readonly uploadService: UploadService) {}
    7. @Post('album')
    8. @UseInterceptors(FileInterceptor('file'))
    9. upload (@UploadedFile() file) {
    10. console.log(file)
    11. return true
    12. }
    13. }

    3.生成静态目录访问上传之后的图片

    useStaticAssets prefix 是虚拟前缀

    1. import { NestFactory } from '@nestjs/core';
    2. import { AppModule } from './app.module';
    3. import {NestExpressApplication} from '@nestjs/platform-express'
    4. import { join } from 'path'
    5. async function bootstrap() {
    6. const app = await NestFactory.create<NestExpressApplication>(AppModule);
    7. app.useStaticAssets(join(__dirname,'images'),{
    8. prefix:"/xiaoman"
    9. })
    10. await app.listen(3000);
    11. }
    12. bootstrap();

     

  • 相关阅读:
    Redis数据类型及命令
    webSocket学习与使用
    v-if和v-for的优先级是什么?
    js 代码中的 “use strict“; 是什么意思 ?
    matlab常微分方程在传染病建模中的应用
    新加坡星银行项目组笔试题面试题
    想没想过自己做个APP?来,机会来了
    Git 是什么(Git 使用详细说明)
    Spring In Action 5 学习笔记 chapter3 拓展-JDBCTemplate连接Oracle
    论文阅读笔记(十二)——Augmenting large language models with chemistry tools
  • 原文地址:https://blog.csdn.net/qq1195566313/article/details/126796646