2

下面的这个 HTML 表单(除其他外)使用 express.js 和 multer 将文件上传到服务器。如果选择了文件,它可以正常工作,但如果文件被遗漏,则不会

<form id="uploadform" method="post" action="/upload" enctype="multipart/form-data">
    <p> Description: <input type="text" name="description"></p>
    <p><input type="file" name="img"></p>
    <p><input id="submit_upload" type="submit" value="Submit"></p>
</form>

我的 Node.js 应用程序包括中间件 multer。

var express = require('express');
var app = express();
var multer = require('multer');

app.use(multer(
    {
        dest: './public/img/',
        rename: function (fieldname, filename) {
            return filename + Date.now();
        }
    }));

提交表单后,我将被重定向到/upload,因为它在 HTML-Upload 表单中定义为action="/upload"。在我的 Node.js 脚本中,表单条目将按如下方式处理:

app.post('/upload', function (req, res) {
    var form_description = req.body.description;
    var form_datei = JSON.stringify(req.files.img.name);
    form_datei = form_datei.substring(1, form_datei.length - 1);
    //  insert operations into database get placed here
    res.redirect('/');
});

如果我没有在表单中选择文件并仅使用插入的文本提交,则甚至不会提交文本。相反,我的控制台和浏览器窗口会显示一条很长的错误消息,如下所示:

TypeError: Cannot read property 'name' of undefined

如果没有选择文件, 如何提交表单?文件上传应该是可选的。 谢谢你的帮助!

4

1 回答 1

5

问题是当您尝试在req.files.img.name. 由于req.files.imgwill return undefined,因此您无法读取那里的属性。

在尝试使用之前检查文件是否已提交:

app.post('/upload', function (req, res) {
    var form_description = req.body.description;
    if(req.files.img) {
        var form_datei = JSON.stringify(req.files.img.name);
        form_datei = form_datei.substring(1, form_datei.length - 1);
        //  insert operations into database get placed here
    }
    res.redirect('/');
});
于 2015-03-30T15:25:53.923 回答