C# VARMAX二进制图像
我将图像存储在数据库中的C# VARMAX二进制图像,c#,asp.net,sql,coolite,ext.net,C#,Asp.net,Sql,Coolite,Ext.net,我将图像存储在数据库中的varbinary(max)字段中 我试图在我的表格上显示一个图像。我尝试了很多不同的方法,但都没有表现出来 这是我的代码: //I am adding an image in my form Ext.Net.Image image = new Ext.Net.Image(); image.ID = "imgShow"; FormLayout1.Items.Add(image); byte[] buffer = q.TckLogo; MemoryStream memS
varbinary(max)
字段中
我试图在我的表格上显示一个图像。我尝试了很多不同的方法,但都没有表现出来
这是我的代码:
//I am adding an image in my form
Ext.Net.Image image = new Ext.Net.Image();
image.ID = "imgShow";
FormLayout1.Items.Add(image);
byte[] buffer = q.TckLogo;
MemoryStream memStream = new MemoryStream();
memStream.Write(buffer, 0, buffer.Length);
// it is giving error because of FromStream
image.items.Add(Image.FromStream(memStream));
如何在表单中显示图像
我正在使用Ext.Net(Coolite)。在web应用程序中,图像控件有一个
ImageUrl
属性,指向将返回图像的服务器端脚本。我不熟悉Ext.Net.Image
,但我认为您需要使用http处理程序来处理映像:
public class ImageHandler : IHttpHandler
{
public void ProcessRequest(HttpContext context)
{
var id = context.Request["id"];
byte[] imageData = FetchImageFromDb(id);
context.Response.ContentType = "image/png";
context.Response.OutputStream.Write(imageData, 0, imageData.Length);
}
public bool IsReusable
{
get { return true; }
}
}
然后将图像控制点指向此通用处理程序:
Ext.Net.Image image = new Ext.Net.Image();
image.ID = "imgShow";
// pass some id to the generic handler which will
// allow it to fetch the image from the database
// and stream it to the response
image.ImageUrl = "~/ImageHandler.ashx?id=123";
FormLayout1.Items.Add(image);
image.items.Add(image);
我不清楚Ext.Net在这里是什么,也不清楚您为什么要使用它,但是FromStream的用法表明您对is感到困惑;但是,当您不应使用System.Drawing(从web应用程序绘制)时,该事件是无意义的。如果您只是尝试将图像返回到客户端,那么在许多情况下您根本不需要处理它——只需将BLOB直接发送到客户端即可
不相关,但正如Jon所指出的,您还试图从MemoryStream的末尾读取数据。在这一行->image.Controls.Add(image.FromStream(memStream));Ext.Net.Image“”也不包含“FromStream”签出的定义