Вспомогательный метод HTML для
есть HTMLHelper
для загрузки файлов? В частности, я ищу замену
<input type="file"/>
использование ASP.NET MVC HTMLHelper.
или, если я использую
using (Html.BeginForm())
что такое HTML-элемент управления для загрузки файла?
8 ответов:
HTML Загрузить файл ASP MVC 3.
модель: (обратите внимание, что атрибут FileExtensionsAttribute доступен в MvcFutures. Он будет проверять расширения файлов на стороне клиента и на стороне сервера.)
public class ViewModel { [Required, Microsoft.Web.Mvc.FileExtensions(Extensions = "csv", ErrorMessage = "Specify a CSV file. (Comma-separated values)")] public HttpPostedFileBase File { get; set; } }
HTML View:
@using (Html.BeginForm("Action", "Controller", FormMethod.Post, new { enctype = "multipart/form-data" })) { @Html.TextBoxFor(m => m.File, new { type = "file" }) @Html.ValidationMessageFor(m => m.File) }
действие контроллера:
[HttpPost] public ActionResult Action(ViewModel model) { if (ModelState.IsValid) { // Use your file here using (MemoryStream memoryStream = new MemoryStream()) { model.File.InputStream.CopyTo(memoryStream); } } }
вы также можете использовать:
@using (Html.BeginForm("Upload", "File", FormMethod.Post, new { enctype = "multipart/form-data" })) { <p> <input type="file" id="fileUpload" name="fileUpload" size="23" /> </p> <p> <input type="submit" value="Upload file" /></p> }
У меня был этот же вопрос некоторое время назад и наткнулась на один из постов Скотта Хансельмана:
реализация загрузки файлов HTTP с помощью ASP.NET MVC в том числе тесты и издевается
надеюсь, что это помогает.
улучшенная версия ответа Паулюса Залиадуониса:
для того, чтобы проверка работала правильно, мне пришлось изменить модель на:
public class ViewModel { public HttpPostedFileBase File { get; set; } [Required(ErrorMessage="A header image is required"), FileExtensions(ErrorMessage = "Please upload an image file.")] public string FileName { get { if (File != null) return File.FileName; else return String.Empty; } } }
в:
@using (Html.BeginForm("Action", "Controller", FormMethod.Post, new { enctype = "multipart/form-data" })) { @Html.TextBoxFor(m => m.File, new { type = "file" }) @Html.ValidationMessageFor(m => m.FileName) }
это необходимо, потому что то, что @Serj Sagan написал о атрибуте FileExtension, работающем только со строками.
или вы могли бы сделать это правильно:
в вашем классе расширения HtmlHelper:
public static MvcHtmlString FileFor<TModel, TProperty>(this HtmlHelper<TModel> helper, Expression<Func<TModel, TProperty>> expression) { return helper.FileFor(expression, null); } public static MvcHtmlString FileFor<TModel, TProperty>(this HtmlHelper<TModel> helper, Expression<Func<TModel, TProperty>> expression, object htmlAttributes) { var builder = new TagBuilder("input"); var id = helper.ViewContext.ViewData.TemplateInfo.GetFullHtmlFieldName(ExpressionHelper.GetExpressionText(expression)); builder.GenerateId(id); builder.MergeAttribute("name", id); builder.MergeAttribute("type", "file"); builder.MergeAttributes(new RouteValueDictionary(htmlAttributes)); // Render tag return MvcHtmlString.Create(builder.ToString(TagRenderMode.SelfClosing)); }
эта строка:
var id = helper.ViewContext.ViewData.TemplateInfo.GetFullHtmlFieldName(ExpressionHelper.GetExpressionText(expression));
генерирует код уникальный для модели, вы знаете, в списках и прочее. модели[0].Имя etc.
создать правильное свойство в модели:
public HttpPostedFileBase NewFile { get; set; }
тогда вам нужно убедиться, что ваша форма будет отправлять файлы:
@using (Html.BeginForm("Action", "Controller", FormMethod.Post, new { enctype = "multipart/form-data" }))
тогда вот тебе помощник:
@Html.FileFor(x => x.NewFile)
использовать
BeginForm
вот он:using(Html.BeginForm("uploadfiles", "home", FormMethod.POST, new Dictionary<string, object>(){{"type", "file"}})
Это также работает:
модель:
public class ViewModel { public HttpPostedFileBase File{ get; set; } }
View:
@using (Html.BeginForm("Action", "Controller", FormMethod.Post, new { enctype = "multipart/form-data" })) { @Html.TextBoxFor(m => m.File, new { type = "file" }) }
действие контроллера:
[HttpPost] public ActionResult Action(ViewModel model) { if (ModelState.IsValid) { var postedFile = Request.Files["File"]; // now you can get and validate the file type: var isFileSupported= IsFileSupported(postedFile); } } public bool IsFileSupported(HttpPostedFileBase file) { var isSupported = false; switch (file.ContentType) { case ("image/gif"): isSupported = true; break; case ("image/jpeg"): isSupported = true; break; case ("image/png"): isSupported = true; break; case ("audio/mp3"): isSupported = true; break; case ("audio/wav"): isSupported = true; break; } return isSupported; }