3

我将图像存储在数据库中的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)。

4

2 回答 2

4

在 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);
于 2011-02-20T09:43:04.117 回答
2

我不清楚 Ext.Net 在这里是什么,或者你为什么使用它,但 FromStream 的用法表明你对System.Drawing.Image.FromStream;感到困惑 但是,这是没有实际意义的事件,因为您不应该从 Web 应用程序中使用System.Drawing。如果您只是想将图像返回给客户端,那么在许多情况下您根本不需要处理它-只需将 BLOB 扔到客户端的线路上即可。

不相关,但正如乔恩指出的那样,您还试图从 MemoryStream 的末尾读取。

于 2011-02-20T09:43:51.723 回答