是否可以将PLUpload与CouchDB结合使用?

时间:2011-08-24 20:03:15

标签: couchdb plupload

我正在寻找将图像上传到我的CouchDB并在上传之前调整大小的可能性,只要它们仍在客户端。 PLUpload提供了这样做的可能性,但我想知道是否可以将它与CouchDB一起使用。

2 个答案:

答案 0 :(得分:2)

经过大量尝试和阅读后,我终于使用PLUpload将图片上传到CouchDB。 主要问题是有一个未记录的属性“file_data_name”,必须手动设置以满足CouchDB的需求。默认值为“name”,但CouchDB期待“_attachments”。我只是通过检查flash运行时的源代码来找到该属性。

下面是我用来初始化PLUpload的javascript:

$("form#pluploadForm #uploader").plupload({
  // General settings
  runtimes : 'flash,silverlight,html5',
  url : 'http://your.path.to.couchdb.com/database/[documentid]',
  max_file_size : '10mb',
  unique_names : true,
  file_data_name : "_attachments",

  // Resize images on clientside if we can
  resize : {width : 320, height : 240, quality : 90},

  // Specify what files to browse for
  filters : [
    {title : "Image files", extensions : "jpg,gif,png"},
    {title : "Zip files", extensions : "zip"}
  ],

  // Flash settings
  flash_swf_url : 'js/plupload.flash.swf',

  // Silverlight settings
  silverlight_xap_url : 'js/plupload.silverlight.xap',

  multipart : true,
  multipart_params : {
    description: "uploadedViaPlupload",
   _rev: "[the current revision of your document]",
  }
});

但是使用这种方法,只能将一个图像转换为一个文档。上传到多个文档是行不通的,但我还没有尝试(还)。

答案 1 :(得分:1)

您要做的是在上传文件之前覆盖PLUploader的BeforeUpload事件以使用您的沙发实例。在下面的方法中,我正在创建一个新文档(使用jquery.couch.js),获取响应并使用新文档的新_id和_rev来设置PLUploader实例选项。

uploader.bind('BeforeUpload', function(up, file) {
  $db.saveDoc({
    users : ['all']
  }, {
    success : function(response) {
      if(response.ok) {
        up.settings.url = 'http://127.0.0.1:5984/filesystem/' + response.id;
        up.settings.multipart_params._rev = response.rev;
        up.trigger("UploadFile", file);
      }
    }
  });
  return false;
});