如何从asp.net的sql server图像字段绑定图像到转发器控件?

时间:2013-01-01 07:31:37

标签: asp.net

我直接将图像存储到数据库中。现在我想将转发器控件绑定到数据库的图像字段。我想加载数据库中的所有图像。

2 个答案:

答案 0 :(得分:1)

传递保存图像的字节流不是在asp.net中执行此操作的正确方法 显示图像的最佳方法是将图像保存在服务器上,并仅将链接传递给图像(例如,使用asp:Image控件)...

在你的情况下,我猜你有两个选择:

  1. 重构应用程序以将图像保存在硬盘上,并仅将URL作为文本字段存储在图像中。

  2. 当您收到请求并想要显示图像时,请将图像保存到服务器上的临时目录中,然后将该临时图像文件的URL传递给客户端。

答案 1 :(得分:1)

您好Nimesh可以使用以下方式从字节数组创建图像并绑定到转发器

<asp:Repeater ID="Repeater1" runat="server">
    <ItemTemplate>
<%# DataBinder.Eval(Container.DataItem, "BookName") %>
<hr>
<%# DataBinder.Eval(Container.DataItem, "BookDescription") %>
<td width="100px">
<p align="left">
 <img src= '<%# GetImageFromByte(DataBinder.Eval(Container.DataItem, "Image")) %>'  
 alt="" style="height:200px;width:200px;border:1px solid gray;"/>
</td>
</p>

//////////////////////// ////////////////////////////    
call  GetImageFromByte  this function from aspx as shown above and convert byte array to image and save in folder then return complete image path 

public string GetImageFromByte(object byt)
 {
  byte[] byts = Convert.ToByte(byt);
  return byteArrayToImage(byts);
}

private string byteArrayToImage(byte[] byteArrayIn)
{
  System.Drawing.Image newImage;
  string strFileName = "Filder path where image need to store " + "yourfilename.gif";
  if (byteArrayIn != null)
   {
    using (MemoryStream stream = new MemoryStream(byteArrayIn))
     {
       newImage = System.Drawing.Image.FromStream(stream);
       newImage.Save(strFileName);
       img.Attributes.Add("src", strFileName);
     }
   lblMessage.Text = "The image conversion was successful.";
  }
  else
  {
    Response.Write("No image data found!");
  }
     return "Filder path where image need to store " + "yourfilename.gif";
 }