在MVC 3 Razor中显示上传的图像

时间:2011-09-06 14:15:52

标签: asp.net-mvc-3 razor

嗯,这个新手在显示上传到服务器的图片时出错了:

模型:

public class Person
{
    public int ID { get; set; }
    public string Name { get; set; }
    public string ImageUrl { get; set; }
}   

controller(上传 - 由[HttpPost]公共ActionResult Create调用):

public void Upload(Person person)
{
    var image = WebImage.GetImageFromRequest();
    var filename = Path.GetFileName(image.FileName);
    var path = Path.Combine(Server.MapPath("~/App_Data/Uploads/Fotos"), filename);
    image.Save(path);
    person.ImageUrl = Url.Content(Path.Combine("~/App_Data/Uploads/Fotos", filename));
}

创建视图:

...
@using (Html.BeginForm("Create", "Person", FormMethod.Post, new { @encType = "multipart/form-data" }))
{
    ...
    @FileUpload.GetHtml(initialNumberOfFiles: 1, allowMoreFilesToBeAdded: false, includeFormTag: false, uploadText: "image")
    ...
    <div>
        <input type="submit" value="Create" /> |
        @Html.ActionLink("Back", "Index")
    </div> 
}

到目前为止,图片已上传到文件夹并保存了网址

现在,我希望在详情视图中看到它

详细视图:

<div class="display-foto">
    <img src="@Url.Content(Server.MapPath(Model.ImageUrl))" alt="IMAGE" />                         
</div>

查看生成的代码,一切似乎都没问题:

<img src="D:\Users\x\Documents\Visual Studio 2010\Projects\CMI_AD\CMI_AD\App_Data\Uploads\Fotos\_nofoto.jpg" alt="IMAGE" />

但事实是除了文字“IMAGE”之外,屏幕上没有任何内容。

我做错了什么?

P.S。我试过没有Server.MapPath,使用相对地址“〜\ App_Data \ Uploads \ Fotos_nofoto.jpg”,结果是一样的。

---编辑---

@ kmcc049:我已经尝试过你的建议创建一个帮手

public static class MyHelpers
{
    public static IHtmlString MyImage(this HtmlHelper htmlHelper, string url)
    {
        var urlHelper = new UrlHelper(htmlHelper.ViewContext.RequestContext);
        var img = new TagBuilder("img");
        img.Attributes["alt"] = "[IMAGE]";
        img.Attributes["src"] = UrlHelper.GenerateContentUrl(url, htmlHelper.ViewContext.HttpContext);
        return MvcHtmlString.Create(img.ToString(TagRenderMode.SelfClosing));
    }
}

视图中的调用:

@Html.MyImage(Model.ImageUrl)

生成的代码是

<img alt="[IMAGE]" src="/App_Data/Uploads/Fotos/_nofoto.jpg" />

但结果是一样的:没有图像:(

---已解决---

显然,App_Data不是保存上传文件的好位置,因为访问它们会导致错误403 - 禁止。我将文件移动到〜/ Uploads / Fotos,它可以工作。

1 个答案:

答案 0 :(得分:3)

这不是有效的HTTP路径。这是计算机上文件夹的路径。

尝试使用UrlHelper.GenerateContentUrl()方法 http://msdn.microsoft.com/en-us/library/system.web.mvc.urlhelper.generatecontenturl.aspx