jquery – 如何在ASP.NET MVC中处理HTML5多文件上传?

前端之家收集整理的这篇文章主要介绍了jquery – 如何在ASP.NET MVC中处理HTML5多文件上传?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我发现 following great thread说明了如何使用新的HTML5 FormData API通过AJAX / Jquery进行文件上传

这是一个略微更新的代码版本,具有较新的JQuery 1.8语法

$(':button').click(function(){
    var formData = new FormData($('form')[0]);
    $.ajax({
        url: '/Upload',//my ASP.NET MVC method
        type: 'POST',// handle the progress report
        xhr: function() {  // Custom XMLHttpRequest
            var myXhr = $.ajaxSettings.xhr();
            if(myXhr.upload){ // Check if upload property exists
                myXhr.upload.addEventListener('progress',progressHandlingFunction,false); // For handling the progress of the upload
            }
            return myXhr;
        },// Form data
        data: formData,//Options to tell jQuery not to process data or worry about content-type.
        cache: false,contentType: false,processData: false
    })
    .done(function(){
        alert("success");
    })
    .fail(function(){
        alert("error");
    });
});

function progressHandlingFunction(e){
    if(e.lengthComputable){
        $('progress').attr({value:e.loaded,max:e.total});
    }
}

这是表格

<form enctype="multipart/form-data">
    <input name="file" type="file" />
    <input type="button" value="Upload" />
</form>
<progress></progress>

在服务器端,我们有这样的东西.

[HttpPost]
public string Upload(HttpPostedFileBase file)
{
    // do something with file
    return "you uploaded a file called " + file.FileName;
}

这很好. UNTIL您决定在文件对话框中使用“multiple”属性,并发送多个文件.

<form enctype="multipart/form-data">
    <input name="file" type="file" multiple="multiple" />
    <input type="button" value="Upload" />
</form>
<progress></progress>

您会在网上找到各种各样的网页,提出以下解决方

public string Upload(IEnumerable<HttpPostedFileBase> files)
{
    foreach(var file in files)
         ...
}

哎呀.不行

public string Upload(List<HttpPostedFileBase> files)
{
    foreach(var file in files)
         ...
}

不.不行

public string Upload(IEnumerable files)
{
    foreach(var file in files)
         ...
}

甚至不编译

public string Upload(HttpPostedFileBase[] files)
{
    foreach(HttpPostedFileBase file in files)
         ...
}

你猜怎么了?不行让我们尝试处理Request.Files. Good老可靠Request.Files.从未失败.

public string Upload()
{
    foreach (HttpPostedFileBase uf in Request.Files)
         ...
}

Spoiler警报:它不起作用

啊哈.得到它了!我将在Request.Files中迭代键.

public string Upload()
{
    foreach(var key in Request.Files.AllKeys)
    {
        var file = Request.Files[key];
    }
}

再一次,它不行.

解决方法

什么工作,是以下,from the blog永远可靠和动态头发的里克斯特拉
public string Upload()
{
    for (int i = 0; i < Request.Files.Count; i++)
    {
        var file = Request.Files[i];
    } 
}

原因之一是传递给Request.Files的文件的集合都具有相同的名称,因为它们来自单个文件上传对话框.

服务器端方法传递包含文件的单个对象,并且由于某种原因,Request.Files是获取它的唯一方法.

希望我通过添加这个来保存某人头痛.

猜你在找的jQuery相关文章