Вы можете BASE64 кодировать содержимое изображения непосредственно в атрибут SRC, однако, я думаю, только Firefox будет анализировать это обратно в изображение.
Обычно я создаю очень легкий HTTPHandler для обслуживания изображений:
using System;
using System.Web;
namespace Example
{
public class GetImage : IHttpHandler
{
public void ProcessRequest(HttpContext context)
{
if (context.Request.QueryString("id") != null)
{
Blob = GetBlobFromDataBase(id);
context.Response.Clear();
context.Response.ContentType = "image/pjpeg";
context.Response.BinaryWrite(Blob);
context.Response.End();
}
}
public bool IsReusable
{
get
{
return false;
}
}
}
}
Вы можете ссылаться на это прямо в теге img:
<img src="GetImage.ashx?id=111"/>
Или вы можете даже создать серверный элемент управления, который сделает это за вас:
using System;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
namespace Example.WebControl
{
[ToolboxData("<{0}:DatabaseImage runat=server></{0}:DatabaseImage>")]
public class DatabaseImage : Control
{
public int DatabaseId
{
get
{
if (ViewState["DatabaseId" + this.ID] == null)
return 0;
else
return ViewState["DataBaseId"];
}
set
{
ViewState["DatabaseId" + this.ID] = value;
}
}
protected override void RenderContents(HtmlTextWriter output)
{
output.Write("<img src='getImage.ashx?id=" + this.DatabaseId + "'/>");
base.RenderContents(output);
}
}
}
Это можно использовать как
<cc:DatabaseImage id="db1" DatabaseId="123" runat="server/>
И, конечно, при необходимости вы можете установить databaseId в коде.