存储用户上传的图像然后在我的网站上显示的最佳方式是什么?
在我看来,第二种方式更方便.
还有一个问题!
在这两种情况下如何以html格式上传此图像?在@Htmldoesent甲肝像什么@Html.FileFor(...),我怎么能得到的数据<input type='file'/>在我的行动?
我感谢任何建议.
Dar*_*rov 15
在我看来,第二种方式更方便.
是的,在我看来也是如此.
在这两种情况下如何以html格式上传此图像?
满容易.与ASP.NET MVC应用程序一样,您首先要设计一个视图模型:
public class MyViewModel
{
[Required]
public HttpPostedFileBase File { get; set; }
}
Run Code Online (Sandbox Code Playgroud)
然后你可以让一个控制器有2个动作(一个渲染视图,另一个渲染文件上传):
public class HomeController: Controller
{
public ActionResult Index()
{
return View(new MyViewModel());
}
[HttpPost]
public ActionResult Index(MyViewModel model)
{
if (!ModelState.IsValid)
{
// the user didn't upload any file =>
// render the same view again in order to display the error message
return View(model);
}
// at this stage the model is valid =>
// you could handle the file upload here
// let's generate a filename to store the file on the server
var fileName = Guid.NewGuid().ToString() + Path.GetFileName(file.FileName);
var path = Path.Combine(Server.MapPath("~/App_Data"), fileName);
// store the uploaded file on the file system
file.SaveAs(path);
// TODO: now you could store the path in your database
// and finally return some ActionResult
// to inform the user that the upload process was successful
return Content("Thanks for uploading. Your file has been successfully stored on our server");
}
}
Run Code Online (Sandbox Code Playgroud)
最后你将有一个相应的强类型视图,它将与表单相关联以上传文件:
@model MyViewModel
@using (Html.BeginForm(null, null, FormMethod.Post, new { enctype = "multipart/form-data" }))
{
<div>
@Html.LabelFor(x => x.File)
@Html.TextBoxFor(x => x.File, new { type = "file" })
@Html.ValidationMessageFor(x => x.File)
</div>
<button type="sybmit">Upload</button>
}
Run Code Online (Sandbox Code Playgroud)
另外我建议您阅读Phil Haack's blog post说明ASP.NET MVC中的文件上载工作.