zoukankan      html  css  js  c++  java
  • HTTP Compression 速用方法

    HTTP Compression Made Easy

    All the modern browsers support HTTP Compression. I tested this solution with Microsoft Internet Explorer 6 SP1, Mozilla Firefox 1.5.0.4, and Konqueror. The latter has a few (known) problems with GZip streams: the pages are displayed correctly, but a warning message is shown.

    When the browser supports HTTP Compression, it sends to the server a specific request header:

    Accept-encoding: gzip, deflate

    When the server receives that header, it can enable HTTP compression. The server, if it decides to use HTTP Compression, must notify the browser using the response header:

    Content-encoding: gzip
    -- or --
    Content-encoding: deflate

    The server then appends the content compressed using the GZip or Deflate algorithm. Note: there are a few other compression algorithms, but they are not supported by all browsers. For further information.

    The Code

    The code is unbelievably simple, and uses the property Filter of the Page object. This property allows you to perform operations on the output stream of the page, for example, replacing every occurrence of :) with the appropriate HTML tag, just to display the smiley (I use this method in my blog). We only have to "replace" the whole output with its compressed bit stream. All we need is to put this simple code snippet in the Page_Load method:

    protected void Page_Load(object sender, EventArgs e) {
    if(Request.Headers["Accept-encoding"] != null &&
    Request.Headers["Accept-encoding"].Contains("gzip")) {
    Response.Filter = new GZipStream(Response.Filter,
    CompressionMode.Compress, true);
    Response.AppendHeader("Content-encoding", "gzip");
    }
    else if(Request.Headers["Accept-encoding"] != null &&
    Request.Headers["Accept-encoding"].Contains("deflate")) {
    Response.Filter = new DeflateStream(Response.Filter,
    CompressionMode.Compress, true);
    Response.AppendHeader("Content-encoding", "deflate");
    }
    }

    The code "plugs" a GZipStream or a DeflateStream into the Filter object (it's an instance of System.IO.Stream), trying to detect which algorithm the browser supports. Note: the two classes (GZipStream and DeflateStream) use the same compression algorithm.

    Refinements

    Since it seems that Konqueror has problems with GZip/Deflate, we should disable HTTP Compression for that browser. We can do that by checking the User Agent. The code then becomes:

    protected void Page_Load(object sender, EventArgs e) {
      if(!Request.UserAgent.ToLower().Contains("konqueror")) {
        if(Request.Headers["Accept-encoding"] != null &&
           Request.Headers["Accept-encoding"].Contains("gzip")) {
              Response.Filter = new GZipStream(Response.Filter,
                                CompressionMode.Compress, true);
              Response.AppendHeader("Content-encoding", "gzip");
        }
        else if(Request.Headers["Accept-encoding"] != null &&
                Request.Headers["Accept-encoding"].Contains("deflate")) {
              Response.Filter = new DeflateStream(Response.Filter,
                                CompressionMode.Compress, true);
              Response.AppendHeader("Content-encoding", "deflate");
        }
      }
    }

    Conclusions and Disclaimer

    As the article's title states, this is a quick and dirty solution, with all its problems, bugs, and worst-practices. It should be considered a mere proof-of-concept, although it actually works. In the coming weeks, I'll investigate deeply into this topic because I believe it may actually become a nice way to implement HTTP Compression on a per-page basis.

  • 相关阅读:
    DataFrame遍历所有元素
    linux 安装redis 和系统学习redis
    接口
    安装idea教程
    Hello World!
    通过特征交互检测生成文本分类的层次解释《Generating Hierarchical Explanations on Text Classification via Feature Interaction Detection》(LIME算法、神经网络预测的分层解释CD和ACD、Shapley Value夏普利值、Leave-One-Out留一法、HEDGE)
    数字图像处理 乱记
    高傲的审稿人
    两项技能
    人其实会变的
  • 原文地址:https://www.cnblogs.com/chuncn/p/1458192.html
Copyright © 2011-2022 走看看