ASP.Net MVC - Img Src服务器路径

时间:2012-10-09 15:40:42

标签: asp.net-mvc image razor view

Visual Studio 2012 - ASP.net - MVC 4

我在显示存储在数据库中的服务器路径中的图像时遇到了麻烦。

我正在使用HttpPostedFileBase来检索用户上传的文件:

using (var uow = _db.CreateUnitOfWork())
            {
                if (imageUpload != null && imageUpload.ContentLength > 0)
                {
                    var fileName = Path.GetRandomFileName() + Path.GetExtension(imageUpload.FileName);
                    var path = Path.Combine(System.Web.Hosting.HostingEnvironment.MapPath("~/Uploads"), fileName);
                    imageUpload.SaveAs(path);
                    achievement.ImageLoc = path;
                }

                uow.Add(achievement);
                Save(uow);
                return true;
            }

这会将上传文件的绝对路径保存到数据库中,并将文件保存到服务器上。当我尝试检索此路径以在视图中显示图像文件时,我得到的是一个空白方块,就像找不到文件一样(关于:右键单击时为空白 - >复制图像URL)。我知道路径是正确的,因为我在不同的视图中使用它以允许用户下载文件,这是正常工作。此外,我允许用户编辑成功删除旧文件并上传新文件的文件。我唯一的问题是在视图中显示图像。

我试过了:

<img src="@Html.Encode(Model.ImageLoc)" />
<img src=@Url.Content(Model.ImageLoc)" />

有人能提出任何建议吗?

2 个答案:

答案 0 :(得分:13)

您已在数据库中存储了图像的绝对路径,但您需要使用相对路径来引用它:

<img src="@Url.Content("~/Uploads/" + System.IO.Path.GetFileName(Model.ImageLoc))" alt="" />

生成的HTML必须如下所示:

<img src="/Uploads/tccxdfu0.nde.jpg" alt="" />

而不是:

<img src="\\PDC2\sites\t\<site.co.uk>\public_html\Uploads\tccxdfu0.nde.jpg" alt="" />

因为客户端无法从服务器访问此类文件夹。

答案 1 :(得分:0)

看看使用

http://msdn.microsoft.com/en-us/library/system.web.mvc.mvchtmlstring%28VS.100%29.aspx 我怀疑它正在被编码,因此没有像你期望的那样输出。