我直接将图像存储到数据库中。现在我想将转发器控件绑定到数据库的图像字段。我想加载数据库中的所有图像。
答案 0 :(得分:1)
传递保存图像的字节流不是在asp.net中执行此操作的正确方法
显示图像的最佳方法是将图像保存在服务器上,并仅将链接传递给图像(例如,使用asp:Image
控件)...
在你的情况下,我猜你有两个选择:
重构应用程序以将图像保存在硬盘上,并仅将URL作为文本字段存储在图像中。
当您收到请求并想要显示图像时,请将图像保存到服务器上的临时目录中,然后将该临时图像文件的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";
}