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

编程入门 行业动态 更新时间:2024-10-09 03:30:08

使用Express的可通过节点格式化的文件上传<a href=https://www.elefans.com/category/jswz/34/1771377.html style=多个文件时,会对其进行处理"/>

使用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的可通过节点格式化的文件上传多个文件时,会对其进行处理

本文发布于:2024-05-07 12:55:16,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1756341.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:多个   对其   可通过   节点   文件上传

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!