我在db中有一个表,其中包含以下内容: - CountryID,CountryName和CountryImage。
现在我正在尝试在索引中显示图像,我在视图中有以下内容: -
<td>
@if (item.Image != null)
{
<img src="@Model.GetImage(item.Image)" alt="@item.CountryName"/>
}
然后在ViewModel中我有: -
public FileContentResult GetImage(byte[] image)
{
if (image != null)
return new FileContentResult(image, "image/jpeg");
else
{
return null;
}
}
但是我无法正常看到图像。
我做错了什么?
提前感谢您的帮助和时间
更新
好的所以我在视图中实现了以下内容: -
<td>
@if (item.Image != null)
{
<img src="@Url.Action("GetImage", "CountryController", new { id = item.CountryID })" alt="@item.CountryName" />
}
</td>
并在CountryController中: -
public ActionResult GetImage(int id)
{
var firstOrDefault = db.Countries.Where(c => c.CountryID == id).FirstOrDefault();
if (firstOrDefault != null)
{
byte[] image = firstOrDefault.Image;
return File(image, "image/jpg");
}
else
{
return null;
}
}
但是当我尝试调试代码时,ActionResult GetImage没有被点击
答案 0 :(得分:18)
两种可能性。
写一个控制器动作,而给定一个图像id会返回这个图像:
public ActionResult GetImage(int id)
{
byte[] image = ... go and fetch the image buffer from the database given the id
return File(image, "image/jpg");
}
然后:
<img src="@Url.Action("GetImage", "SomeController", new { id = item.Id })" alt="@item.CountryName" />
显然现在在您的初始模型中,您不需要Image
属性。随后将在负责该操作的控制器操作中检索此信息。
另一种可能性是使用data URI scheme将图像嵌入为base64字符串,但它可能并未得到所有浏览器的广泛支持:
<img src="data:image/jpg;base64,@(Convert.ToBase64String(item.Image))" alt="@item.CountryName" />
在这种情况下,您不需要控制器操作,因为图像直接作为base64字符串嵌入到标记中。