• 小满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();

     

  • 相关阅读:
    【基本算法题-2022.7.26】4. 起床困难综合症
    【Kotlin】OkHttp框架实现网络下载
    数学推理题:张王李赵陈五对夫妇聚会,见面握手
    服务瘫痪数日,是火灾的锅还是Kakao的锅?
    mybatis-plus分页
    ubuntu源码安装aria2
    自学Python04-学会Python中的空格
    二、体验Linux系统(文件目录、shell)
    Android Termux安装MySQL,内网穿透实现公网远程访问
    转载 | 自动驾驶开源数据集总结
  • 原文地址:https://blog.csdn.net/qq1195566313/article/details/126796646