[英]Varbinary max image
我在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用法表明你很困惑的是System.Drawing.Image.FromStream
; 但是,事件没有实际意义,因为您不应该使用 Web应用程序中的System.Drawing。 如果你只是想将图像返回给客户端,你不应该在所有处理它在许多情况下-只是扔BLOB沿着电线到客户端。
不相关,但Jon注意到你也试图从MemoryStream的末尾读取。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.