2016-03-07 27 views
5

Używam plików jQuery Form Plugin i multer do przesyłania plików na mój serwer. Działa to dobrze, ale próbuję przekazać dodatkowy parametr, który określi, gdzie dokładnie plik zostanie zapisany.Przesyłanie pliku i przekazywanie dodatkowego parametru za pomocą multera

Mam następujący kod, który chciałbym przedłużyć się zachowywać jak stwierdził:

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> 

Client 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 Route

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"); 
    }); 
}); 

Uwaga: Wiem, że nie sprawdzam typów MIME ani nie odkażam plików użytkownika, ale w tej chwili jest to dla mnie głównie drugorzędne.

+0

Można wziąć 'savePath' od' req.body'. –

+0

Cóż, otrzymuję obiekt tylko dla 'userFile',' savePath' nigdy nie pojawił się w 'req.body' przy moich próbach. –

Odpowiedz

11

Problem polega na tym, że multer zapisuje najpierw pliki, a następnie zapisuje do req pozostałą część formularza - np. Ukryte pola.

Spróbuj tego:

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

Dziękuję bardzo za wyjaśnienia i przepraszam za opóźnienie! Działa świetnie! –