在 MVC 5 中上传图像时 Request.Files.Count 始终为 0

2023-12-28

我的模型上有一个 Post 控制器,带有一些字符串字段和图像。完全相同的代码适用于 MVC4,但在 MVC 5 中 Request.Files.Count 始终为 0

我的模型具有用于图像的 byte[] 而不是 HttpPostedFileBase

My View:

@using (Html.BeginForm("Create", "HotelManager", FormMethod.Post, new { enctype = "multipart/form-data", data_ajax = "false" }))
{
    @Html.AntiForgeryToken()
    @Html.TextBoxFor(model => model.Title, new { @class = "form-control" })
    @Html.TextAreaFor(model => model.Description, new { @class = "form-control", @rows = "7" })
    <input type="file" class="form-control filestyle">
    <input type="submit" value="Submit" class="btn btn-block" />
}

我尝试省略 data_ajax = "false" 但没有用。

我的帖子控制器如下:

    [HttpPost]
    [ValidateAntiForgeryToken]
    public ActionResult Create([Bind(Include = "Title,Description,Image")] Hotel hotel)
    {
        if (ModelState.IsValid)
        {
            // deal with the uploaded file
            if (Request.Files.Count > 0)
            {
                HttpPostedFileBase file = Request.Files[0];

                if (file != null && file.ContentLength > 0)
                {
                    // Code to process image, resize, etc goes here
                }
            }

        // Other code to add the hotel to db goes here
    }

在调试器中我看到 Request.Files.Count 始终为零,我不知道为什么? 我已经从另一个 MVC4 项目复制了视图和控制器代码,它运行良好。

Key Value
Request POST /HotelManager/Create HTTP/1.1
Accept  text/html, application/xhtml+xml, */*
Referer http://localhost:4976/HotelManager/Create
Accept-Language en-US,en;q=0.5
User-Agent  Mozilla/5.0 (Windows NT 6.3; WOW64; Trident/7.0; Touch; ASU2JS; rv:11.0) like Gecko
Content-Type    multipart/form-data; boundary=---------------------------7de207070a24
Accept-Encoding gzip, deflate
Host    localhost:4976
Content-Length  946
DNT 1

在 IE Developer 窗口中,我看到表单主体是空的。


我浪费了很多时间,结果发现我需要做的就是使用 name 属性

 <input type="file" name="somename"> 

我的新项目中缺少 name 属性。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

在 MVC 5 中上传图像时 Request.Files.Count 始终为 0 的相关文章

随机推荐