不能使用dropzone和multer多次上传

Sat*_*ato 5 node.js express dropzone.js multer

从dropzone.js:

如果您将uploadMultiple选项设置为true,则Dropzone会将[]附加到名称之后。

因此对于multer,array('file')将不起作用,因为 fieldname: 'file[0]'

如果我上传多个文件,它将是fieldname: 'file[0]' fieldname: 'file[1]'...。

我必须使用upload.any(),有没有办法在multer中做一些上传后的钩子?

bgt*_*gth 2

请使用下面

HTML:

<form action="/uploadImages" id="buldUploadForm" enctype="multipart/form-data" method="post">
    <div class="dropzone dz-clickable" id="uploadDropzone">
       <div class="dz-default dz-message" data-dz-message="">
          <span>Drop files here to upload</span>
       </div>
    </div>
    <br />
    <input type="submit" class="btn btn-primary" id="submitAllProcess" value="Upload Images" name="submit" />
</form>
Run Code Online (Sandbox Code Playgroud)

JavaScript:

Dropzone.autoDiscover = false;

function paramNameForSend() {
   return "userParamName";
}

$(document).ready(function() {
  var myDropzone = new Dropzone("#uploadDropzone", {
    url: '/uploadImages',
    maxFilesize: 5, // MB
    maxFiles: 10,
    autoProcessQueue: false,
    uploadMultiple: true,
    paramName: paramNameForSend,
    method: 'post',
    parallelUploads: 10,
    init: function() {
        var myDropzone = this;

        $("#buldUploadForm").submit(function (e) {
            e.preventDefault();
            e.stopPropagation();
            myDropzone.processQueue();
        }); 
      }
    });
});
Run Code Online (Sandbox Code Playgroud)

穆尔特:

var storage =   multer.diskStorage({
  destination: function (req, file, callback) {
    callback(null, './uploads');
  }
});

var uploadMultiple = multer({ storage : storage}).array('userParamName', 10);
Run Code Online (Sandbox Code Playgroud)