//继承= “System.Web.Mvc.ViewPage< FilmFestWeb.Models.ListVideosViewModel>” 中
<asp:Content ID="Content2" ContentPlaceHolderID="MainContent" runat="server">
<h2>ListVideos</h2>
<% foreach(BusinessObjects.Video vid in Model.VideoList){%>
<div class="videoBox">
<%= Html.Encode(vid.Name) %>
<img src="<%= vid.ThumbnailImage %>" />
</div>
<%} %>
</asp:Content>
// ListVideosViewModel
public class ListVideosViewModel
{
public IList<Video> VideoList { get; set; }
}
//视频
public class Video
{
public long VideoId { get; set; }
public long TeamId { get; set; }
public string Name { get; set; }
public string Tags { get; set; }
public string TeamMembers { get; set; }
public string TranscriptFileName { get; set; }
public string VideoFileName { get; set; }
public int TotalNumRatings { get; set; }
public int CumulativeTotalScore { get; set; }
public string VideoUri { get; set; }
public Image ThumbnailImage { get; set; }
}
我得到的“红色x”通常与未找到的图像文件相关联。我已经验证了我的数据库表显示在上传图像执行的存储过程之后。任何见解或建议将不胜感激。
答案 0 :(得分:4)
正如我看到你正在使用mvc使用这个看看示例imagedata是byte []数组,imagemimetype是一个字符串,这是你控制器中一个动作的一个例子
public FileContentResult GetImage(int ProductID)
{
Product product = (from p in productsRepository.Products
where p.ProductID == ProductID
select p).First();
return File(product.ImageData, product.ImageMimeType);
}
用它来显示视图中的图像
<img src="<%= Url.Action("GetImage", "Products",
new { Model.ProductID }) %>" />
答案 1 :(得分:0)
您不会从您的数据库返回图像。你将得到一个字节[]。我的建议是创建一个从数据库返回图像的ASP.NET处理程序。然后你可以链接到处理程序。
请看这篇SO帖子,了解如何做到这一点:Dynamically Rendering asp:Image from BLOB entry in ASP.NET
答案 2 :(得分:0)
感谢您的帮助。这就是我解决问题的方法(使用entlib 4.1)
public ThumbnailImage GetThumbnailImageByVideoId( long videoId )
{
Database db = DatabaseFactory.CreateDatabase("Connection String");
DataSet ds = new DataSet();
ThumbnailImage img = null;
try
{
using (DbCommand cmd = db.GetStoredProcCommand("usp_GetThumbnailImageByVideoId"))
{
db.AddInParameter(cmd, "VideoId", DbType.Int64, videoId);
db.LoadDataSet(cmd, ds, "Video");
}
foreach (DataRow dr in ds.Tables["Video"].Rows)
{
if (! string.IsNullOrEmpty(dr["ThumbnailImage"].ToString()))
{
byte[] b = dr["ThumbnailImage"] as byte[];
MemoryStream ms = new MemoryStream(b);
img = new ThumbnailImage();
img.Image = Image.FromStream(ms);
img.ContentType = dr["ImageContentType"].ToString();
}
break;
}
}
catch (Exception ex)
{
throw ex;
}
return img;
}