使用multer在node.js(express)中上传后保留图像文件名和扩展名

2024-01-13

<!doctype html>
<html>

    <body>
        <form action="/upload" method="POST" enctype="multipart/form-data">
            <input type='file' name="image">
            <br>
            <input type="submit" value="submit">
        </form>
   </body>

</html>
var express = require('express');
var router = express.Router();
var multer  = require('multer');
var upload = multer({ dest: 'uploads/',
    filename: function (req, file, cb) {
    cb(null, file.fieldname + '-' + Date.now())
} });

router.post('/upload', upload.single('image'), function(req, res){
    res.send("Uploaded");
});
module.exports = router;

我有这个使用 multer 模块上传图像的基本代码。但是,当文件上传时,它会生成一些随机名称,甚至删除文件扩展名。它只是说输入“文件”。那么如何保留带有扩展名的图像名称。


当您上传文件(使用 multer.single 方法)时,您将获得文件数据

req.file

它是一个对象,具有originalname、mimetype、path 等属性。检查所有文档:https://github.com/expressjs/multer https://github.com/expressjs/multer

但不要相信模仿类型。

如何保留图像名称和扩展名?

a) 使用 req.file 中的数据重命名上传的文件(不喜欢它)

b) 将文件数据(req.file)存储在数据库中

编辑关于重命名: 当所有下载的文件都进入一个目录,并且您将名称更改为原始文件时,可能会出现冲突 - 可能存在同名文件。因此,当您选择这种方式时,您可能应该将文件移动到单独的目录中。

接下来的事情:原始文件名可能包含侮辱性词语或非标准字符(我不知道这是否可能是安全问题)或很长等。

好吧,怎么重命名? 我们可以使用快递包裹fshttps://nodejs.org/api/fs.html https://nodejs.org/api/fs.html和方法:

fs.rename(oldPath, newPath, callback)

or

fs.renameSync(oldPath, newPath)
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

使用multer在node.js(express)中上传后保留图像文件名和扩展名 的相关文章

随机推荐