在写nest项目的时候,写到fileupload 这段时,根据官方文档,发现,上传过来的文件全部都变成了一串加密的编码,例如:
加密编码图示.png
于是本来在issue中希望能够找到解决方法,但是完全没办法解决这类问题。于是博主开始翻阅了nestJS的源码。
FileInterceptor 的 MulterOptions 源码.png
这里我们知道了,nest.js 使用的是multer 来封装的,所以我们可以直接使用multer类来进行自定义处理
根据此github 文档,我们可以直接在uploadController中书写:
import { Controller, Post, UseInterceptors, UploadedFile, FileInterceptor} from '@nestjs/common'; import multer = require('multer'); @Controller('upload') export class UploadController { @Post() @UseInterceptors(FileInterceptor('file', { storage: multer.diskStorage({ destination: (req, file, cb) => { cb(null, 'c:/Users/ke_li/Desktop/test/'); }, filename: (req, file, cb) => { cb(null, file.originalname); }, }), })) async uploade(@UploadedFile() file) { return file; } }
说明:destination类似于option字段 desk,指定uploadfile的目录,filename则是当前upload的file给予指定文件的文件名称, file.originalname 则是 file 在本地的文件名
于是我们获得了以下请求:
postman 请求.png
文件上传的目录
上传的文件.png
这样就完成了我们对文件目录及名称的自定义。
本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。
我来说两句