13_文件上传&静态目录

简介: 13_文件上传&静态目录

通过Nest.js我们可以实现文件上传功能,这样就可以把老婆们都存到服务器里来了,上传功能需要借助multer包实现

  1. 安装multer及其类型声明包

npm install multer

npm install @types/multer

  1. 生成一个upload文件夹用于提供上传服务

nest g res upload

文件上传

设置默认选项

在upload文件夹中设置一些默认选项,通过调用MulterModule中的register方法实现。如果需要异步处理文件上传,可以使用registerAsync

import { Module } from '@nestjs/common';
import { UploadService } from './upload.service';
import { UploadController } from './upload.controller';
import { MulterModule } from '@nestjs/platform-express';
import { diskStorage } from 'multer';
import { extname, join } from 'path';
@Module({
  // 通过imports的方式进行注册
  imports:[MulterModule.register({
    storage:diskStorage({
      // 存放文件的目录
      destination:join(__dirname,'../image'),
      // 重命名文件
      filename:(req,file,callback) => {
        // 使用时间戳 + 文件名称的方式来存储文件
        callback(null,`${new Date().getTime()}` + extname(file.originalname))
      }
    })
  })],
  controllers: [UploadController],
  providers: [UploadService],
})
export class UploadModule {}

MulterModule.register接收一个配置对象,这里列出所有受支持的选项(来源:Multer中文文档

dest or storage

在哪里存储文件

fileFilter

文件过滤器,控制哪些文件可以被接受

limits

限制上传的数据

preservePath

保存包含文件名的完整文件路径

其中,storage需要使用diskStorage函数生成,diskStorage函数同样接收一个配置对象,有两个可用的选项destinationfilename。详细信息如下:

  1. destination用来确定文件的存储位置,其类型可以是和filename一样的函数,也可以是一个字符串。如果没有提供,存储位置将默认为操作系统的临时文件夹。
  2. filename用于确定文件的名称,其类型是一个接收请求信息、文件信息和回调函数的函数。如果没有设置 filename,每个文件将随机设置一个文件名并且没有扩展名
  3. callback的第一个参数是错误信息,第二个是返回的字符串

需要注意的是, Multer不会为文件提供任何扩展名。callback应当返回一个完整的文件名。本例中我们使用extname取出文件的扩展名(.jpg),file.originalname表示用户计算机上文件的完整名称

部署上传服务

在upload.controller.ts中使用FileInterceptor中间件进行部署,该装饰器接收一个字符串类型参数和一个配置对象,字符串要和POST请求体中包含文件的字段名称一致,配置对象和上文MulterModule.register的配置对象格式相同,不过我们这里予以省略

import {
  Controller,
  Post,
  UseInterceptors,
  UploadedFile,
} from '@nestjs/common';
import { UploadService } from './upload.service';
import { CreateUploadDto } from './dto/create-upload.dto';
import { UpdateUploadDto } from './dto/update-upload.dto';
import { FileInterceptor } from '@nestjs/platform-express';
@Controller('upload')
export class UploadController {
  constructor(private readonly uploadService: UploadService) {}
  @Post()
  // @UseInterceptors指示要注册哪个中间件
  @UseInterceptors(FileInterceptor('file'))
  // @UploadedFile从request中取出file
  create(@UploadedFile() file: Express.Multer.File) {
    console.log(file);
    return true;
  }
}

以上,如果文件上传成功则控制台会打印出文件的信息并返回true,我们可以使用ApiFox测试一下

无需关注校验信息(迫真),上传已经成功了。注意参数名一定要是file(和FileInterceptor中定义的一致)

静态目录

和express中的express.static()相同,nest.js也提供了对应方法解决创建静态目录的问题,并且非常方便

import { NestFactory } from '@nestjs/core';
import { AppModule } from './app.module';
// 引入NestExpressApplication接口
import { NestExpressApplication } from '@nestjs/platform-express';
import { join } from 'path';
async function bootstrap() {
  // 传入泛型获取代码提示
  const app = await NestFactory.create<NestExpressApplication>(AppModule);
  // 设置静态目录路径
  app.useStaticAssets(join(__dirname,'..', 'public')
  await app.listen(3000);
}
bootstrap();

很简单,只需要操作main.ts即可。使用app.useStaticAssets()方法创建静态目录,该方法接收两个参数,第一个是字符串,对应服务器上的资源URL,第二个是一个配置对象,可以在里面定义虚拟路径等参数

import { NestFactory } from '@nestjs/core';
import { AppModule } from './app.module';
// 引入NestExpressApplication接口
import { NestExpressApplication } from '@nestjs/platform-express';
import { join } from 'path';
async function bootstrap() {
  // 传入泛型获取代码提示
  const app = await NestFactory.create<NestExpressApplication>(AppModule);
  // 设置静态目录路径
  app.useStaticAssets(join(__dirname,'..', 'public'),{
    prefix:'/nuohang',
  })
  await app.listen(3000);
}
bootstrap();

对第一个例子,访问http://localhost:3000/1680706936282.jpg

对第二个例子,访问http://localhost:3000/nuohang/1680706936282.jpg

目录
相关文章
|
7月前
|
PHP
thinkphp中自定义文件上传
thinkphp中自定义文件上传
42 0
|
3月前
|
Java Spring
springboot静态资源目录访问,及自定义静态资源路径,index页面的访问
本文介绍了Spring Boot中静态资源的访问位置、如何进行静态资源访问测试、自定义静态资源路径和静态资源请求映射,以及如何处理自定义静态资源映射对index页面访问的影响。提供了两种解决方案:取消自定义静态资源映射或编写Controller来截获index.html的请求并重定向。
springboot静态资源目录访问,及自定义静态资源路径,index页面的访问
|
7月前
文件上传地址的获取方法
文件上传地址的获取方法
64 1
|
7月前
|
JavaScript 前端开发
Gulp 打包压缩 js 文件到指定目录详细流程(修改文件名与后缀)
Gulp 打包压缩 js 文件到指定目录详细流程(修改文件名与后缀)
44 0
|
存储 Java
Java实现文件上传到本地(自定义保存路径)
Java实现文件上传到本地(自定义保存路径)
811 0
|
PHP
thinkphp修改图片路径
thinkphp修改图片路径
132 0
|
存储 JSON 安全
electron如何自定义目录,修改文件名保存下载的网络文件
很多同学觉得用localstorage可以代替vuex, 对于不变的数据确实可以,但是当两个组件共用一个数据源(对象或数组)时,如果其中一个组件改变了该数据源,希望另一个组件响应该变化时,localstorage无法做到,原因就是区别1。
electron如何自定义目录,修改文件名保存下载的网络文件
|
前端开发
前端上传文件保存到变量中
前端上传文件保存到变量中
前端上传文件保存到变量中
|
文件存储
Yii2.0框架提供了内置的文件访问组件,可以通过配置只允许访问指定的目录,防止非法文件的包含。这个如何使用?
Yii2.0框架提供了内置的文件访问组件,可以通过配置只允许访问指定的目录,防止非法文件的包含。这个如何使用?
149 0