Blueimp multi file uploader con ASP.NET MVC 3
-
16-11-2019 - |
Domanda
Sto cercando di aggiungere Blueimp file Caricare in un'applicazione MVC e ioM Avendo problemi con la ricezione dei file nell'azione post (sto andando per la funzionalità di caricamento multi file). Come qualcuno per favore aiutami a capire questo?
A mio avviso ho il seguente codice:
<form id="file_upload" enctype="multipart/form-data" action="Home/SaveFile" method="post">
<input type="file" name="file" multiple="true"/>
<button>Upload</button>
<div>Upload files</div>
</form>
<br />
###############################
<table id="files">
</table>
<button id="start_uploads">Start uploads</button>
<button id="cancel_uploads">Cancel uploads</button>
.
Il codice jQuery per il caricamento del file Blueimp è il seguente:
$(document).ready(function () {
$('#file_upload').fileUploadUI({
uploadTable: $('#files'),
downloadTable: $('#files'),
buildUploadRow: function (files, index) {
return $('<tr><td class="file_upload_preview"><\/td>' +
'<td>' + files[index].name + '<\/td>' +
'<td class="file_upload_progress"><div><\/div><\/td>' +
'<td class="file_upload_start">' +
'<button class="ui-state-default ui-corner-all" title="Start Upload">' +
'<span class="ui-icon ui-icon-circle-arrow-e">Start Upload<\/span>' +
'<\/button><\/td>' +
'<td class="file_upload_cancel">' +
'<button class="ui-state-default ui-corner-all" title="Cancel">' +
'<span class="ui-icon ui-icon-cancel">Cancel<\/span>' +
'<\/button><\/td><\/tr>');
},
buildDownloadRow: function (file) {
return $('<tr><td>' + file.name + '<\/td><\/tr>');
},
beforeSend: function (event, files, index, xhr, handler, callBack) {
handler.uploadRow.find('.file_upload_start button').click(callBack);
}
});
$('#start_uploads').click(function () {
$('.file_upload_start button').click();
});
$('#cancel_uploads').click(function () {
$('.file_upload_cancel button').click();
});
});
.
e all'interno del controller il seguente metodo di azione:
[AcceptVerbs(HttpVerbs.Post)]
public ActionResult SaveFile(IEnumerable<HttpPostedFileBase> files)
{
foreach (HttpPostedFileBase file in files)
{
//some file upload magic
}
return View("MyView");
}
.
Sto usando MVC 3.
Nel metodo di azione, se l'argomento è di tipo Ienumerable, riceve NULL e se l'argomento è di tipo httpPostedfilebase riceve i file in modo strano e il metodo di azione non funziona come supporti.
Qualsiasi tipo di aiuto è molto apprezzato, grazie.
Cheers!
Soluzione
The SaveFile
controller action will be called for each file. So it should look like this:
[HttpPost]
public ActionResult SaveFile(HttpPostedFileBase file)
{
//some file upload magic
// return JSON
return Json(new
{
name = "picture.jpg",
type = "image/jpeg",
size = 123456789
});
}
And if you want to handle multiple upload files in the same request you may take a look at the respective section of the documentation.
Altri suggerimenti
To get the files you could use,
foreach (string inputTagName in Request.Files)
{
HttpPostedFileBase file = Request.Files[inputTagName];
}
I know that this is an old issue, but just to point in here. In addition to Darin Dimitrov post - returned json should be in format compatible with jQuery File Upload - which expects array even if one file is transmitted. For example:
return Json(
new
{
files = new[]{
new {
name = "www.png",
size = "1234567"
}
}
}
);