【问题标题】:ASP.Net MVC - Img Src Server PathASP.Net MVC - Img Src 服务器路径
【发布时间】:2012-09-29 23:57:49
【问题描述】:

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)" />

有人可以提出任何建议吗?

【问题讨论】:

  • 你检查过输出的Html吗? (即在它呈现的页面上查看源代码)。快速浏览一下它放在src 标签中的链接可能会让您更好地了解问题所在。要检查的内容包括路径被双重编码(即您在通往数据库的途中对其进行一次编码,然后在离开时再次对其进行编码)或在路径末尾缺少“/”。
  • \public_html\Uploads\tccxdfu0.nde.jpg" />

标签: asp.net-mvc image razor view


【解决方案1】:

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

<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="" />

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

【讨论】:

    【解决方案2】:

    看看使用

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

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2021-02-12
      • 2010-11-14
      • 2017-08-26
      • 2014-01-20
      • 2014-11-28
      • 2015-04-06
      • 1970-01-01
      • 2014-08-01
      相关资源
      最近更新 更多