AJAX 文件上传 - HttpPostedFileBase 参数始终为 null MVC 4

AJAX file upload - HttpPostedFileBase parameter always null MVC 4

我正在尝试通过 AJAX 请求将 CSV 文件发送到控制器操作,但是,HttpPostedFileBase 参数始终为空。因此,我无法访问我要发送的文件的内容。请有人告诉我哪里出错了才能解决这个问题。

这是我的控制器:

[HttpPost]
public ActionResult ImportCSV(HttpPostedFileBase file)
{
    var files = Request.Files.Count; // This returns 1. However, 'file' parameter is null

    // Process the CSV file here...

    return View();
}

这是我的 HTML:

<table class="fieldset">
    <tr>
        <td>Select File:</td>
        <td>
            <!--FILE TEXTFIELD-->
            <input type="file" id="file" name="file" class="hide file-upload" />

            <!--OVERLAY-->
            <div id="filename" class="file-textbox"></div>

            <!--ELIPSES-->
            <button id="filestyle" class="elipses button green-button">...</button>
        </td>
        <td>
            <!--UPLOAD-->
            <button type="button" id="btnUpload" class="button green-button upload">Upload</button>
            <div class="loading"></div>
        </td>
    </tr>
</table>

这是我的 JS:

var UploadModule = (function ($) {

"use strict";

var btnElipses;
var btnChangeUpload;
var btnUpload;
var Files = {};

var init = function () {
    btnElipses = $(".elipses");
    btnChangeUpload = $(".file-upload");
    btnUpload = $(".upload");

    bindEvents();
};

var bindEvents = function () {
    btnElipses.on("click", browse);
    btnChangeUpload.on("change", change);
    btnUpload.on("click", upload);
};

var upload = function (e) {

    // Prevent default actions
    e.stopPropagation();
    e.preventDefault();

    // The file object is passed through in the event (hopefully)
    var csv = new FormData();

    // Get file and append to form data
    $.each(Files["csv"], function (key, value) {
        csv.append(key, value);
    });

    // Send file
    $.ajax({
        url: '/Factors/ImportCSV',
        type: 'POST',
        data: csv,
        dataType: "json",
        cache: false,
        contentType: false,
        processData: false,

        success: function (data) {
            //Handle success
        },
        error: function (xhr, status, errorThrown) {
            //Handle error
        }
    });
};

var browse = function (e) {
    $('#file').click();
};

var change = function (e) {
    // Set file name overlay to name of file
    $('#filename').text($(e.target).val().split('\').pop());

    // Set value of csv to the file
    Files["csv"] = e.target.files;
};

init();

})(jQuery);

您可以直接从Request.Files阅读:

 var file = Request.Files[0];

或:

var file = Request.Files["file"];

其中 "file" 是输入元素名称

您可能还想阅读 this post