繁体   English   中英

显示从数据库中取出的二进制流作为html内的“图像” <img> 标签

[英]display a binary stream fetched from database as “image” inside the html as an <img> tag

我试图在Web表单上显示从数据库中以二进制流的形式提取的图像。 你能谈谈这个吗?

我正在开发一个用户拥有个人资料的项目,每个用户都有自己的个人资料图片显示在主页中。 这张照片来自数据库。

这是我用来获取流的代码!

TestDBDataContext context1 = new TestDBDataContext();

            var r = (from a in context1.ImageTables where a.Id == 8 select a).First();

           MemoryStream stream = new MemoryStream(r.FileImage.ToArray());

谢谢

Base64编码您的二进制文件并插入图像标记,如下所示(更改mimetype以适应):

<img src=" ENCODED BINARY HERE">

你就是这样做的,但我不会这样做,因为有些浏览器无法处理它(IE6)。 最好先保存到文件并按常规方式执行。

我过去所做的是将图片网址设置为aspx页面,如下所示:

<img src="getLogo.aspx" alt="Logo" />

然后,在getLogo.aspx的代码隐藏中,我做了以下事情:

Response.BinaryWrite( imageData );
Response.ContentType = "image/gif";

其中imageData是您的图像作为字节数组

我会将图像保存到网站内的目录,该目录可以使用无意义的名称(例如数据库中的记录的主键或GUID)访问外部调用者(即图像子目录),然后将href添加到此目录文件在网页中。

将内存流保存到文件使用:

MemoryStream memoryStream = new MemoryStream();
     using (FileStream fileStream = new FileStream(FilePath, FileMode.Open, FileAccess.Write))
     {
       memoryStream.SaveTo(fileStream);
     }

然后把文件名放在html中。

首先为图像提供一个单独的.aspx文件(实际上我支持IHttpHandler重载,但原理是相同的,让我们一次只引入一个新概念)。

.aspx文件将继承代码隐藏,并且没有内容。 所以它会有<%@ Page %>指令而没有别的。

在代码隐藏中,在页面加载事件处理程序中,获取图像,并将响应的内容类型设置为适当的值(或者,如果所有图像都是image / png,则可以只进行硬编码那)。 然后将图像写入输出。

TestDBDataContext context1 = new TestDBDataContext();
int id;
if(int.TryParse(Request.QueryString["id"], out id))
{
  var r = (from a in context1.ImageTables where a.Id == 8 select a).FirstOrDefault();
  if(r != null)
  {
    Response.ContentType = r.ContentType;
    Response.BinaryWrite(r.FileImage.ToArray());
    return;
  }
}
//code to handle 404 not found for no such image here (send error message or Server.Transfer to error page, etc.

然后你可以使用<img src="profileImg.aspx?id=8" alt="" />等。

性能改进是从数据库一次获得4k块的字节并将它们写入Response.OutputStream ,而不是内存中的一个大型数组。 对于小文件而言,差别并不重要,但对于非常大的文件来说,这可能是相当大的(如“现在我的网络服务器不再重复!”相当可观)。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM