2016-03-07 41 views
5

我正在使用jQuery Form Pluginmulter将文件上传到我的服务器。这工作得很好,但我想传递一个额外的参数,它将确定文件将保存在哪里。上传文件并传递附加参数

我有以下的代码,我谨向表现得说:

HTML

<form id="uploadForm" 
     enctype="multipart/form-data" 
     action="/files" 
     method="post"> 
    <input type="file" id="userFile" name="userFile"/> 
    <input type="text" hidden id="savePath" name="savePath" value="path"/> 
</form> 

客户端JS

uploadForm.submit(function() { 
    $(this).ajaxSubmit({ 

     error: function(xhr) { 
      console.log('Error: ' + xhr.status); 
     }, 

     success: function(response) { 
      console.log('Success: ' + response); 
     } 
    }); 

    return false; 
}); 

Node.js的路线

app.post(APIpath + "file",function(req,res){ 
    var storage = multer.diskStorage({ 
     destination: absoluteServePath+ "/" + config.filePath, 
     filename: function (req, file, cb) { 
      cb(null, file.originalname); 
     } 
    }); 
    var upload = multer({ storage : storage}).any(); 

    upload(req,res,function(err) { 
     if(err) { 
      console.log(err); 
      return res.end("Error uploading file."); 
     } 
     res.end("File has been uploaded"); 
    }); 
}); 

注意:我知道我没有检查mimetypes或消毒用户文件,但它现在主要是次要的。

+0

您可以从'req.body'采取'savePath'。 –

+0

好吧,我只是得到'userFile'的对象,'savePath'从来没有出现在'req.body'中。 –

回答

11

问题是,multer先保存文件,然后才写入req表格的其余部分 - 如隐藏字段。

试试这个:

app.post(APIpath + "file",function(req,res){ 
    var storage = multer.diskStorage({ 
     destination: tmpUploadsPath 
    }); 
    var upload = multer({ storage : storage}).any(); 

    upload(req,res,function(err) { 
     if(err) { 
      console.log(err); 
      return res.end("Error uploading file."); 
     } else { 
      console.log(req.body); 
      req.files.forEach(function(f) { 
      console.log(f); 
      // and move file to final destination... 
      }); 
      res.end("File has been uploaded"); 
     } 
    }); 
}); 
+0

非常感谢您的解释,并为延迟感到抱歉!完美的作品! –