我的视图中有一个@Html.BeginForm
,可以让用户上传图片并添加一些图片细节。
以下是视图:
@Html.BeginForm("SaveImage", "Listing", FormMethod.Post, new { enctype = "multipart/form-data" }))) {
<div id="modalAddImage" class="modal hide fade" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" aria-hidden="true">
<div class="modal-header">
<button type="button" class="close" data-dismiss="modal" aria-hidden="true">×</button>
<h3 id="myModalLabel">Modal header</h3>
</div>
<div class="modal-body">
<p>Image</p>
<input type="file" name="file"></input>
@foreach (Image translation in Model.Listing.Images)
{
@Html.TextBoxFor(m => m.Description)
}
</div>
<div class="modal-footer">
<button class="btn" data-dismiss="modal" aria-hidden="true">Close</button>
<button class="btn btn-primary">Save changes</button>
</div>
</div>
}
我在此之前有一个不同的@Html.BeginForm
用于其他内容。
这是我的控制者:
[HttpPost]
public ActionResult SaveImage(HttpPostedFileBase file)
{
if (file!= null && file.ContentLength > 0)
{
var fileName = Path.GetFileName(file.FileName);
var path = Path.Combine(Server.MapPath("~/App_Data/uploads"), fileName);
file.SaveAs(path);
}
return View("Maintain");
}
当我在SaveImage
中放置一个断点时,file始终为null。我试图上传大图像和小图像。
任何人都可以看到我发生了可怕的错误吗?
答案 0 :(得分:3)
您可以这样做:
[HttpPost]
public ActionResult SaveImage(HttpPostedFileBase file)
{
if (Request.Files.Count > 0)
{
foreach (string upload in Request.Files)
{
if (upload != null)
{
var fileName = Path.GetFileName(file.FileName);
var path = Path.Combine(Server.MapPath("~/App_Data/uploads"), fileName);
Request.Files[upload].SaveAs(path);
}
}
}
return View("Maintain");
}
答案 1 :(得分:1)
遇到了同样的问题然后意识到我没有在我的表单中指定(enctype =“multipart / form-data”)