调用processFile(文件)时未完全处理Dropzone文件

时间:2015-07-30 05:07:09

标签: mongodb meteor dropzone.js gridfs

我在我的Meteor应用程序中以编程方式创建Dropzone而不是将文件发布到URL我将它们存储在带有CollectionFS / GridFS的MongoDB中,并通过迭代遍历每个文件调用processFile(File) getQueuedFiles数组,如下所示:

dz.getQueuedFiles().forEach(function(element) {
          Images.insert(element, function(err, fileObj){
            if (err){
              alert("Erreur!");
            } else {
              var imageId = fileObj._id;
              arrayOfImageIds.push(imageId);
              dz.processFile(element);
            }
          })

一切顺利,直到文件大小更大。然后,某种程度上进度条被卡住中途并且processFile永远不会完成(并且队列没有被清空)。即使我只是孤立dz.processFile(元素)并注释掉DB写入文件挂起在客户端。

这是我的Dropzone设置:

Template.logoUpload.onRendered(function (){
  Dropzone.autoDiscover = false;

  dz = new Dropzone("form#dropzone", {
    dictDefaultMessage : "DROP YOUR LOGO HERE",
    autoProcessQueue: false,
    addRemoveLinks: true,
    dictRemoveFile: "Delete",
    maxFiles: 2,
    maxFilesize: 5,
    maxThumbnailFilesize: 5,
    accept: function(file, done){
      done();
    },

  init: function() { 
      this.on("addedfile", function(file) {
        Session.set("files", this.files.length);
        if (this.getAcceptedFiles().length > 1) {
          alert("max 2 files allowed");
          this.removeFile(file);
        }
      }),

      this.on("removedfile", function(file) {
        Session.set("files", this.files.length);
      }),

      this.on("queuecomplete", function(file, response){
        console.log("SUCCESFULLY UPLOADED");
        console.log(arrayOfImageIds);
        Session.set("imageIds", arrayOfImageIds);
      })
  }
  });
});

任何人都知道如何解决这个问题?

1 个答案:

答案 0 :(得分:0)

您是否尝试过增加文件块大小?

var imageStore = new FS.Store.GridFS("images", {
    chunkSize: 1024*1024  // optional, default GridFS chunk size in bytes (can be overridden per file).
                         // Default: 2MB. Reasonable range: 512KB - 4MB
});

Images = new FS.Collection("images", {
  stores: [imageStore]
});