HttpPostedFileBase返回null到我的控制器
本文关键字:我的 控制器 null 返回 HttpPostedFileBase | 更新日期: 2023-09-27 18:08:37
各位,我试着从用户那里得到3张照片,所以我的模型是这样的:
namespace DomainClass
{
using System;
using System.Collections.Generic;
using System.Web.Http;
public partial class CompanyMember
{
public CompanyMember()
{
this.Proficiencies = new HashSet<Proficiency>();
}
[DisplayName(" شناسه")]
public int Id { get; set; }
[DisplayName("عکس")]
public string ImageUrl { get; set; }
[DisplayName("کارت ملی")]
public string IntCartCopy { get; set; }
[DisplayName("شناسنامه")]
public string IdentityCartCopy { get; set; }
[System.ComponentModel.DataAnnotations.Schema.NotMapped]
public HttpPostedFileBase ImgFileImageUrl { get; set; }
[System.ComponentModel.DataAnnotations.Schema.NotMapped]
public HttpPostedFileBase ImgFileIntCartCopy { get; set; }
[System.ComponentModel.DataAnnotations.Schema.NotMapped]
public HttpPostedFileBase ImgFileIdentityCartCopy { get; set; }
public virtual Company Company { get; set; }
public virtual ICollection<Proficiency> Proficiencies { get; set; }
}
所以在我看来,为了获得图片,我创建了3个输入标签,像这样:
@model DomainClass.CompanyMember
@{
ViewBag.Title = "اضافه کردن اعضاء";
}
@using (Html.BeginForm("Create", "CompanyMember", FormMethod.Post,
new { id = "form", enctype = "multipart/form-data" }))
{
@Html.ValidationSummary(true)
<div class="wrapper-left">
<div class="wrapper-top-addCompany">
اعضاء
<div style="float: left; padding-left: 20px;">
<div class="divider"></div>
<div class="buttonPossion">
<input type="submit" value="ذخیره اطلاعات" Class="buttonSave" />
@Html.ActionLink("بازگشت", "index", new {companyId = ViewBag.companyId}, new {@class = "buttonBlueLink"})
</div>
<div class="divider"></div>
</div>
</div>
@Html.HiddenFor(model => model.CompanyId)
<div class="wrapper">
<div class="wrapper-Member" style="padding-bottom: 30px; margin-bottom: 5px; width: 98%">
<h2>
اضافه کردن اعضاء جدید
</h2><br/><br/><br/>
<div class="editor-label">
@Html.LabelFor(model => model.Name) @Html.ValidationMessageFor(model => model.Name)
</div>
<div class="editor-field">
@Html.EditorFor(model => model.Name)
</div>
<div class="editor-label">
@Html.LabelFor(model => model.Family) @Html.ValidationMessageFor(model => model.Family)
</div>
<div class="editor-field">
@Html.EditorFor(model => model.Family)
</div>
<div class="editor-label">
@Html.LabelFor(model => model.EducationLevel) @Html.ValidationMessageFor(model => model.EducationLevel)
</div>
<div class="editor-field">
@Html.EditorFor(model => model.EducationLevel)
</div>
<div class="editor-label">
@Html.LabelFor(model => model.University) @Html.ValidationMessageFor(model => model.University)
</div>
<div class="editor-field">
@Html.EditorFor(model => model.University)
</div>
<div class="editor-label">
@Html.LabelFor(model => model.Mobile) @Html.ValidationMessageFor(model => model.Mobile)
</div>
<div class="editor-field">
@Html.EditorFor(model => model.Mobile)
</div>
<div class="editor-label">
@Html.LabelFor(model => model.Telephone) @Html.ValidationMessageFor(model => model.Telephone)
</div>
<div class="editor-field">
@Html.EditorFor(model => model.Telephone)
</div>
<div class="editor-label">
@Html.LabelFor(model => model.Address) @Html.ValidationMessageFor(model => model.Address)
</div>
<div class="editor-field">
@Html.EditorFor(model => model.Address)
</div>
<div class="editor-label">
@Html.LabelFor(model => model.Email) @Html.ValidationMessageFor(model => model.Email)
</div>
<div class="editor-field">
@Html.EditorFor(model => model.Email)
</div>
<div class="editor-label">
@Html.LabelFor(model => model.InternationalCode) @Html.ValidationMessageFor(model => model.InternationalCode)
</div>
<div class="editor-field">
@Html.EditorFor(model => model.InternationalCode)
</div>
<div class="editor-label">
@Html.LabelFor(model => model.Field) @Html.ValidationMessageFor(model => model.Field)
</div>
<div class="editor-field">
@Html.EditorFor(model => model.Field)
</div>
<div class="editor-label">
@Html.LabelFor(model => model.Job) @Html.ValidationMessageFor(model => model.Job)
</div>
<div class="editor-field">
@Html.EditorFor(model => model.Job)
</div>
<div class="editor-label">
@Html.LabelFor(model => model.Share) @Html.ValidationMessageFor(model => model.Share)
</div>
<div class="editor-field">
@Html.EditorFor(model => model.Share)
</div>
<div class="editor-label">
@Html.LabelFor(model => model.Password) @Html.ValidationMessageFor(model => model.Password)
</div>
<div class="editor-field">
@Html.EditorFor(model => model.Password)
</div>
<div class="editor-label">
@Html.LabelFor(model => model.ImageUrl)
</div>
<div class="editor-field">
@Html.HiddenFor(model => model.ImageUrl)
<input id="imgProfile" type="file" name="ImgFileImageUrl"/>
</div>
<div class="editor-label">
@Html.LabelFor(model => model.IntCartCopy)
</div>
<div class="editor-field">
@Html.HiddenFor(model => model.IntCartCopy)
<input id="imgIntCartCopy" type="file" name="ImgFileIntCartCopy"/>
</div>
<div class="editor-label">
@Html.LabelFor(model => model.IdentityCartCopy)
</div>
<div class="editor-field">
@Html.HiddenFor(model => model.IdentityCartCopy)
<input id="imgIdentityCartCopy" type="file" name="ImgFileIdentityCartCopy"/>
</div>
</div>
</div>
</div>
}
<div>
@Html.ActionLink("Back to List", "Index")
</div>
@section Scripts {
@Scripts.Render("~/bundles/jqueryval")
}
但提交3 HttpPostedFileBase列返回null在我的控制器我检查了文件的值,所有它们都是null为什么?我的if条件返回false
public ActionResult Create(CompanyMember companyMember)
{
if (companyMember.ImgFileImageUrl != null && companyMember.ImgFileIntCartCopy!=null && companyMember.ImgFileIdentityCartCopy!=null)
{
saving
}
}
张贴的文件可在
Request.Files
您应该读取它们并通过控制器动作保存到db。为此,使用输入的名称作为Request。文件表索引,例如:
HttpPostedFileBase img = Request.Files["ImgFileIntCartCopy"];
if(img != null)
img.SaveAs(path + img.FileName);