时间:2011-02-20 09:24:04

标签: 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 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)。

2 个答案:

答案 0 :(得分: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);

答案 1 :(得分:2)

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

无关,但正如Jon所说,你也试图从MemoryStream的末尾读取。