首页 > 编程 > .NET > 正文

ASP.NET 2.0 里输出文本格式流

2024-07-10 13:08:27
字体:
来源:转载
供稿:网友


  在用 asp.net 编程时,打开一个页面一般是通过指定超链接地址,调用指定的页面文件(.html、.aspx)等方法。

  但是,如果即将打开的页面文件的内容是在程序中动态生成,或者是从数据库的表里取出的,我们怎么把这些内容展示出来呢?

  我们最直接的想法是,把这些内容先保存成网页文件,再调用它。这种方法当然是可以的,但不是最好的方法,因为这样会在 web 服务器上生成

  许多临时文件,这些文件可能永远也用不着了。

  另一种最好的方法是利用文本格式流,把页面内容动态地展示出来。例如,有一个页面:

……
    <iframe src=""></iframe>
    ……

  需要用 iframe 打开一个页面,这个页面的内容是动态生成的。我们可以写一个 .ashx 文件(这里命名为 html.ashx)来处理。.ashx 文件里实现了 ihttphandler 接口类,可以直接生成浏览器使用的数据格式。

html.ashx 文件内容:

<%@ webhandler language="c#" class="handler" %>
    using system;
    using system.io;
    using system.web;
    public class handler : ihttphandler {
     public bool isreusable {
      get {
       return true;
      }
     }
     public void processrequest (httpcontext context)
        {
      // set up the response settings
      context.response.contenttype = "text/html";
      context.response.cache.setcacheability(httpcacheability.public);
      context.response.bufferoutput = false;
      stream stream = null;
        string html = "<html><body>成功: test of txt.ashx</body></html>";
        byte[] html2bytes = system.text.encoding.ascii.getbytes(html);
        stream = new memorystream(html2bytes);
      if (stream == null)
            stream = new memorystream(system.text.encoding.ascii.getbytes("<html><body>get nothing!</body></html>"));
      //write text stream to the response stream
      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);
      }
     }

    }

  html.ashx 文件中首先把 string 字符串转化为字节(byte)数组,然后再生成内存中的 memorystream 数据流,最后写到 outputstream 对象中,显示出来。

  这样以来,我们就可以通过 <iframe src="html.ashx"></iframe> 来展示动态生成的页面,显示“成功: test of txt.ashx”的网页内容。html.ashx 文件中 string html = "<html><body>成功: test of txt.ashx</body></html>"; 一句中,变量 html 的内容完全可以从数据库中得到(事先把一个 html 文件内容保存在数据库中)。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表