admin管理员组

文章数量:814986

使用Express的可通过节点格式化的文件上传多个文件时,会对其进行处理

在Express上上传具有节点可识别的文件就这么简单

app.post('/upload', function(req, res) {
    // do something with req.files
});

现在已保存文件

表格:(multiple =“ multiple”是HTML5的一项功能,允许用户选择要上传的多个文件]

<form method="post" enctype="multipart/form-data" action="upload">
    <input type="text" name="title"/>
    <input type="file" name="upload" multiple="multiple"/>
    <input type="submit" value="upload" id="s3form_submit"/>
</form>

如果我将此行添加到上传代码中

console.log(req.files.upload.path);

上传一个文件时,该路径会显示在控制台中。但是,当我上传多个文件时,它在控制台中只是未定义。如何获取每个文件的日志内容?使用for循环?

[GitHub上可编节点的示例在您上传多个文件时记录了每个文件:.js(我曾尝试在Express中使用此代码,但没有用)它完全符合我的要求,但是如何在Express应用程序中做到这一点?

回答如下:

它通过将下面的行移动到app.configure函数的底部来工作。在此处阅读有关Express中有关中间件的顺序的重要性:http://expressjs/guide.html#middleware

app.use(express.bodyParser({ uploadDir:__dirname + '/public/uploads' }));

并且使用此处理程序:

app.post('/upload', function(req, res){
    var form = new formidable.IncomingForm(),
    files = [],
    fields = [];
    form.on('field', function(field, value) {
        fields.push([field, value]);
    })
    form.on('file', function(field, file) {
        console.log(file.name);
        files.push([field, file]);
    })
    form.on('end', function() {
        console.log('done');
        res.redirect('/forms');
    });
    form.parse(req);
});

本文标签: 使用Express的可通过节点格式化的文件上传多个文件时,会对其进行处理