单独的文件上传node.js

时间:2015-07-11 05:20:28

标签: html node.js multer

我想知道处理两个单独文件上传的最简单方法,一个用于图像,另一个用于音频。现在我正在使用multer并将所有分段上传内容上传到同一位置。我可以为两个文件上传指定不同的位置吗?

1 个答案:

答案 0 :(得分:0)

假设您要将文件保存到磁盘,可以执行以下操作:

var storage = multer.diskStorage({
    destination: function(req, file, cb) {
        if (file.fieldname === 'image-file') {
            return cb(null, 'folder-for-image-uploads');
        }

        if (file.fieldname === 'audio-file') {
            return cb(null, 'folder-for-audio-uploads');
        }

        cb(new Error('Unknown fieldname: ' + file.fieldname));
    },
    filename: function(req, file, cb) {
        if (file.fieldname === 'image-file') {
            return cb(null, 'image-filename.jpg');
        }

        if (file.fieldname === 'audio-file') {
            return cb(null, 'audio-filename.mp3');
        }

        cb(new Error('Unknown fieldname: ' + file.fieldname));
    }
});

var upload = multer({storage: storage});

app.post('/endpoint', upload.fields([{name: 'image-file', maxCount: 1}, {name: 'audio-file', maxCount: 1}]), function(req, res) {
    // handle request, files already saved to disk
    res.sendStatus(200);
}

要使其生效,您需要input HTML元素的名称以匹配fieldname属性,例如:

<form method="POST" action="/endpoint" enctype="multipart/form-data">
    <input type="file" name="image-file">
    <input type="file" name="audio-file">
    <input type="submit">Submit</input>
</form>