Asp.net core 文件为空,请单击“Razor”

Asp.net core 文件为空,请单击“Razor”,asp.net-core,razor,image-uploading,iformfile,Asp.net Core,Razor,Image Uploading,Iformfile,我正在尝试绑定上传的图像,但在将此图像发送到控制器时遇到问题 我正在使用Razor和.NETCore2.2。 我的控制器 [HttpPost(nameof(MealController))] [Authorize(Roles = UserRoles.Moderator)] public IActionResult Update(MealModel meal, IFormFile pic) { if (ModelState.I

我正在尝试绑定上传的图像,但在将此图像发送到控制器时遇到问题

我正在使用Razor和.NETCore2.2。 我的控制器

[HttpPost(nameof(MealController))]
        [Authorize(Roles = UserRoles.Moderator)]
        public IActionResult Update(MealModel meal, IFormFile pic)
        {
            if (ModelState.IsValid)
            {
                try
                {
                    var changedMeal = _mapper.Map<MealModel, MealDTO>(meal);
                    _mealService.Update(changedMeal, pic);
                }
                catch (Exception e)
                {
                    return NotFound();
                }

                return RedirectToAction("Index");
            }

            return View(meal);
        }
[HttpPost(名称(MealController))]
[授权(角色=用户角色.主持人)]
公共IActionResult更新(MealModel膳食,IFormFile图片)
{
if(ModelState.IsValid)
{
尝试
{
var changedMeal=_mapper.Map(膳食);
_mealService.Update(变更MEAL,pic);
}
捕获(例外e)
{
返回NotFound();
}
返回操作(“索引”);
}
返回视图(膳食);
}
我的表格

<form class="form" method="post" asp-controller="Meal" asp-action="Update">
            <div class="modal-content">
                <div class="modal-header">
                    <h5 class="modal-title" id="exampleModalLabel">Продукт</h5>
                    <button type="button" class="close" data-dismiss="modal" aria-label="Close">
                        <span aria-hidden="true">&times;</span>
                    </button>
                </div>
                <div class="modal-body">
                    <div class="product">
                        <div class="product-img">
                            <div class="selector">
                                <img src="@Model.ImagePath" class="img-thumbnail" id="selectedImg" alt="Product Image"/>
                                <div class="form-group">
                                    <input type="file" class="custom-file-input" id="pic-input" name="pic"
                                           onchange="readURL(this, 'selectedImg')">
                                    @* <label class="custom-file-label" for="pic-input"></label> *@
                                </div>
                            </div>
                        </div>
                        <div class="product-info">
                            <div class="form-group name">
                                <label for="name">Назва продукту</label>
                                <input class="form-control" type="text" placeholder="Назва" id="name" name="name" asp-for="Name"
                                       value="@Model.Name">
                            </div>

                            <div class="form-group">
                                <label for="name">Ціна</label>
                                <input class="form-control" placeholder="Price" id="price" type="number" asp-for="Price"
                                       value="@Model.Price">
                            </div>
                            <div class="form-group">
                                <label for="name">Вага</label>
                                <input class="form-control" id="weight" type="number" asp-for="Weight"
                                       value="@Model.Weight">
                            </div>

                            <div class="comments">
                                <textarea class="form-control" rows="3" cols="5" placeholder="Склад" asp-for="Description" value="@Model.Description"></textarea>
                            </div>
                            <input type="hidden" asp-for="MealGroupId" value="@Model.MealGroupId"/>
                            <input type="hidden" asp-for="Id" value="@Model.Id"/>
                            @* <input type="hidden" asp-for="ImagePath" value="@Model.ImagePath"/> *@
                        </div>
                    </div>

                </div>
                <div class="modal-footer">
                    <div class="action-button">
                        <button type="submit"
                                class="btn btn-success ok-button">
                            <span>Додати</span>
                        </button>
                        <button type="reset"
                                class="btn btn-danger remove-button">
                            <span>Відмінити</span>
                        </button>
                    </div>
                </div>
            </div>
        </form>

Продукт
&时代;
@*  *@
Назва продукту
Ціна
Вага
@*  *@
Додати
Відмінити

调试时,
ifformfile
总是
null
。我试着使用[FromForm],但没用。我在谷歌上搜索,发现我的
名称
在形式和参数名称上有所不同,但它有效果。请你给我一点提示,告诉我如何解决这个问题。谢谢你,祝你今天愉快

您必须将
enctype
属性设置为
多部分/表单数据
,才能将文件发送到服务器

<form class="form" method="post" asp-controller="Meal" asp-action="Update" enctype="multipart/form-data">

回答得很好。