ASP.Net MVC AJAX上传文件到控制器正在提交两次

时间:2015-10-22 08:46:43

标签: c# jquery asp.net ajax asp.net-mvc

我有一个ASP.Net MVC应用程序。我需要用ajax将文件发送到Controller。但我有两次请求。

@using (Ajax.BeginForm("Create", "MyController", new { area = "" },
    new AjaxOptions
    {
        HttpMethod = "POST",
        OnBegin = "onBegin",
        OnSuccess = "onSuccess(data)"
    }, new { enctype = "multipart/form-data", id = "myform" }))
    {

    <section class="col col-md-12">
        @Html.DisplayFor(model => model.Title)
        <label class="input">
            @Html.TextBoxFor(model => model.Title)
        </label>
    </section>

    <section class="col-md-6">
        <label class="label text-left">
            My File
        </label>
        <label for="file" class="input input-file">
            <div class="button">
                <input name="files" type="file" id="file" onchange=" this.parentNode.nextSibling.value = this.value ">choose...
            </div>
            <input type="text" readonly="" class="text-right">
        </label>
    </section>

    <button type="submit" class="btn btn-primary">
        Submit
    </button>
}

控制器操作,当使用AJAX发布我的数据时,我的操作中有两次请求。

[HttpPost]
public ActionResult Create(HttpPostedFileBase files, CreateViewModel model)
{
    // The Request comes here twice.
}

和我在页面中的引用,

<script src="/Scripts/jquery.min.js"></script>
<script src="/Scripts/jquery.unobtrusive-ajax.min.js"></script>
<script src="/Scripts/jquery.validate.min.js"></script>
<script src="/Scripts/jquery.validate.unobtrusive.min.js"></script>
<script src="/Scripts/bootstrap/bootstrap.min.js"></script>
<script src="/Scripts/jquery.form.js"></script>
$(function () {
    $('#myform').ajaxForm({
        beforeSubmit: ShowRequest,
        success: SubmitSuccesful,
        error: AjaxError
    });
});

function ShowRequest(formData, jqForm, options) {
    var queryString = $.param(formData);

    alert('BeforeSend method: \n\nAbout to submit: \n\n' + queryString);
    return true;
}

function AjaxError() {
    alert("An AJAX error occured.");
}

function SubmitSuccesful(responseText, statusText) {
    alert("SuccesMethod:\n\n" + responseText);
}

我该怎么办?

1 个答案:

答案 0 :(得分:2)

问题是您正在使用ASP.NET MVC AjaxForm以及jQuery ajaxForm插件。当您按下提交按钮时,MVC也会发送请求以及jQuery。