zoukankan      html  css  js  c++  java
  • ASP.NET2.0 Person Web Site:将图片以二进制的从数据库读取

    在ASP.NET Person Web Site Starter Kits中,图片的是以二进制的形式存放在数据库里,微软提供的读取该图片的方式是通过handler.ashx来实现的.

    1 handler.ashx
       首先你所看到的对图片的引用都是类似如下
    <img src="Handler.ashx?AlbumID=<%# Eval("AlbumID") %>
    的形式,也就是你所看到的每一个图片都由Handler.ashx动态生成,所以在你保存你所看到的"图片"时,它的命名都是Handler.ashx.
       使用handler.ashx而不是handler.aspx来引用图片并不是一定的,换句话说,你可以将该文件改为handler.aspx并没有本质的区别,不过根据微软的文档,使用*.ashx作为扩展名的文档比*.aspx的文档性能高,因为它减少了控件树的生成.

    下面是handler.ashx的改动的代码,你可以直接拿过来用在自己的项目里,也就是如果你已经将图片保存以image类型保存在数据库里就可以用如下代码读取

    using System;
    using System.IO;
    using System.Web;

    public class Handler : IHttpHandler {

     
     public void ProcessRequest (HttpContext context) {
      // Set up the response settings
      context.Response.ContentType = "image/jpeg";
      context.Response.Cache.SetCacheability(HttpCacheability.Public);
      context.Response.BufferOutput = false;
     
      Stream stream = null;
        const int buffersize = 1024 * 16;
      byte[] buffer = new byte[buffersize];
      int count = stream.Read(buffer, 0, buffersize);
      while (count > 0) {
       context.Response.OutputStream.Write(buffer, 0, count);
       count = stream.Read(buffer, 0, buffersize);
      }

     }

    }
    上面代码中,读取的核心代码以蓝色显示,这里大buffersize限制为1024*16,当然这不是必须的,一种更为常用的方法是动态读取文件大小,然后再设置buffersize的值

  • 相关阅读:
    在Oracle中添加用户 赋权 修改暗码 解锁
    Ubuntu Linux 8.04 Vsftp 假造用户设置
    用一个实例讲解DB2数据库游标轮回的成果
    解说Oracle数据库自动增长列的完成过程
    MSN登录错误“80072efd”解决办法
    再学 GDI+[61]: 路径画刷(1) SetCenterColor、SetSurroundColors
    WinAPI: 测试 BitBlt
    两个 CopyRect
    再学 GDI+[58]: 路径 保存与读取路径数据
    再学 GDI+[62]: 路径画刷(2) SetCenterPoint、GetCenterPoint
  • 原文地址:https://www.cnblogs.com/mqingqing123/p/363718.html
Copyright © 2011-2022 走看看