我正在尝试创建一个创建模型对象页面。我正在使用带有c#的asp.net mvc。在我的项目中,我正在尝试创建一个有书籍的图书馆应用程序,我们可以从有图片的应用程序添加书籍。所以我的创建控制器就像这样,
[HttpPost]
public ActionResult Create([Bind(Exclude = "id,bringBack,borrower,isBorrowed")]Book bookToCreate, HttpPostedFileBase picture1)
{
try
{
if (picture1.ContentLength > 0)
{
var fileName = Path.GetFileName(picture1.FileName);
var path = Path.Combine(Server.MapPath("~/App_Data/pictures"), fileName);
picture1.SaveAs(path);
}
// TODO: Add insert logic here
_entities.AddToLibrary(bookToCreate);
_entities.SaveChanges();
return RedirectToAction("ListBooks");
}
catch
{
return View();
}
}
我的观点是这样的,
<%@ Page Language="C#" Inherits="System.Web.Mvc.ViewPage<MvcApplication2.Models.Book>" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
<title>Create</title>
</head>
<body>
<% using (Html.BeginForm(new { enctype = "multipart/form-data" }))
{%>
<%: Html.ValidationSummary(true) %>
<fieldset>
<legend>Fields</legend>
<div class="editor-label">
<%: Html.LabelFor(model => model.name) %>
</div>
<div class="editor-field">
<%: Html.TextBoxFor(model => model.name) %>
<%: Html.ValidationMessageFor(model => model.name) %>
</div>
<div class="editor-label">
<%: Html.LabelFor(model => model.author) %>
</div>
<div class="editor-field">
<%: Html.TextBoxFor(model => model.author) %>
<%: Html.ValidationMessageFor(model => model.author) %>
</div>
<div class="editor-label">
<%: Html.LabelFor(model => model.picture) %>
</div>
<div class="editor-field">
<%: Html.TextBoxFor(model => model.picture) %>
<%: Html.ValidationMessageFor(model => model.picture) %>
</div>
<input type='file' name='picture1' id='picture1' />
<p>
<input type="submit" value="Create" />
</p>
</fieldset>
<% } %>
<div>
<%: Html.ActionLink("Back to List", "Index") %>
</div>
我尝试了很多东西,但我无法上传任何文件。我该怎么办?
答案 0 :(得分:0)
尝试从Request
获取已发布的文件。
var picture1 = this.Request.Files["picture1"];
答案 1 :(得分:0)
在您的图书模型中应该是属性
HttpPostedFileBase picture1