过滤器-全站压缩

2024-03-23 23:58
文章标签 过滤器 压缩 全站

本文主要是介绍过滤器-全站压缩,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

当使用response写数据的时候,将数据写到过滤器的缓冲内,然后再过滤器中拿到数据,帮用户压缩了之后,将数据返回给浏览器,就可以实现全站压缩,用户访问的所有数据都会被压缩,过滤器代码如下所示:

Html代码 
  1. package cn.itcast.web.filter;  
  2.   
  3. import java.io.ByteArrayOutputStream;  
  4. import java.io.IOException;  
  5. import java.io.OutputStreamWriter;  
  6. import java.io.PrintWriter;  
  7. import java.util.zip.GZIPOutputStream;  
  8.   
  9. import javax.servlet.Filter;  
  10. import javax.servlet.FilterChain;  
  11. import javax.servlet.FilterConfig;  
  12. import javax.servlet.ServletException;  
  13. import javax.servlet.ServletOutputStream;  
  14. import javax.servlet.ServletRequest;  
  15. import javax.servlet.ServletResponse;  
  16. import javax.servlet.http.HttpServletRequest;  
  17. import javax.servlet.http.HttpServletResponse;  
  18. import javax.servlet.http.HttpServletResponseWrapper;  
  19.   
  20. public class GzipFilter implements Filter {  
  21.   
  22.     public void doFilter(ServletRequest req, ServletResponse resp,  
  23.             FilterChain chain) throws IOException, ServletException {  
  24.         HttpServletRequest request = (HttpServletRequest) req;  
  25.         HttpServletResponse response = (HttpServletResponse) resp;  
  26.           
  27.         //将数据进入到缓冲中,然后取出进行压缩  
  28.         ByteArrayOutputStream bout = new ByteArrayOutputStream();  
  29.           
  30.         MyResponse myresponse = new MyResponse(response);  
  31.         chain.doFilter(request, myresponse);   //servlet  myresponse.getOutputStream  MyServletOutputStream.write  
  32.           
  33.         byte data[] = myresponse.getData();  //拿到的是目标资源想写给浏览器的数据  
  34.         System.out.println("原始大小:" + data.length);  
  35.           
  36.         byte gzip[] = gzip(data);   
  37.         response.setHeader("content-encoding", "gzip");  
  38.         response.setHeader("content-length", gzip.length + "");  
  39.         response.getOutputStream().write(gzip);   
  40.           
  41.     }  
  42.       
  43.     private byte[] gzip(byte[] data) throws IOException {  
  44.           
  45.         ByteArrayOutputStream bout = new ByteArrayOutputStream();  
  46.         GZIPOutputStream gout = new GZIPOutputStream(bout); //压缩  
  47.         gout.write(data);  
  48.         gout.close();  //进底层流  
  49.         return bout.toByteArray();  //从底层流写数据  
  50.     }  
  51.   
  52.     class MyResponse extends HttpServletResponseWrapper{  
  53.         private HttpServletResponse response;  
  54.         private ByteArrayOutputStream bout  = new ByteArrayOutputStream();  
  55.         private PrintWriter pw;  
  56.           
  57.         public MyResponse(HttpServletResponse response){  
  58.             super(response);  
  59.             this.response = response;  
  60.         }  
  61.         @Override  
  62.         public ServletOutputStream getOutputStream() throws IOException {  
  63.             return new MyServletOutputStream(bout);  
  64.         }  
  65.           
  66.         @Override  
  67.         public PrintWriter getWriter() throws IOException {  
  68.             pw = new PrintWriter(new OutputStreamWriter(bout,response.getCharacterEncoding()));   //PrintWriter.writer("中国");  
  69.             return pw;  
  70.         }  
  71.         //返回缓冲区的数据  
  72.         public byte[] getData(){  
  73.             if(pw!=null){  
  74.                 pw.close();  
  75.             }  
  76.             return bout.toByteArray();  
  77.         }  
  78.     }  
  79.       
  80.     class MyServletOutputStream extends ServletOutputStream{  
  81.   
  82.         private ByteArrayOutputStream bout;  
  83.         public MyServletOutputStream(ByteArrayOutputStream bout){  
  84.             this.bout = bout;  
  85.         }  
  86.         //写到缓冲中   
  87.         @Override  
  88.         public void write(int b) throws IOException {  
  89.             bout.write(b);  
  90.         }  
  91.     }  
  92.       
  93.     public void destroy() {  
  94.         // TODO Auto-generated method stub  
  95.     }  
  96.     public void init(FilterConfig filterConfig) throws ServletException {  
  97.         // TODO Auto-generated method stub  
  98.     }  
  99.   
  100. }  


XML配置如下:

Html代码 
  1. <filter>  
  2.     <filter-name>GzipFilter</filter-name>  
  3.     <filter-class>cn.itcast.web.filter.GzipFilter</filter-class>  
  4.  </filter>  
  5.    
  6.  <filter-mapping>  
  7.     <filter-name>GzipFilter</filter-name>  
  8.     <url-pattern>/*</url-pattern>  
  9.     <dispatcher>FORWARD</dispatcher>  
  10.     <dispatcher>REQUEST</dispatcher>  
  11.  </filter-mapping>  

这篇关于过滤器-全站压缩的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/839916

相关文章

Servlet中配置和使用过滤器的步骤记录

《Servlet中配置和使用过滤器的步骤记录》:本文主要介绍在Servlet中配置和使用过滤器的方法,包括创建过滤器类、配置过滤器以及在Web应用中使用过滤器等步骤,文中通过代码介绍的非常详细,需... 目录创建过滤器类配置过滤器使用过滤器总结在Servlet中配置和使用过滤器主要包括创建过滤器类、配置过滤

Qt实现文件的压缩和解压缩操作

《Qt实现文件的压缩和解压缩操作》这篇文章主要为大家详细介绍了如何使用Qt库中的QZipReader和QZipWriter实现文件的压缩和解压缩功能,文中的示例代码简洁易懂,需要的可以参考一下... 目录一、实现方式二、具体步骤1、在.pro文件中添加模块gui-private2、通过QObject方式创建

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu

hdu1565(状态压缩)

本人第一道ac的状态压缩dp,这题的数据非常水,很容易过 题意:在n*n的矩阵中选数字使得不存在任意两个数字相邻,求最大值 解题思路: 一、因为在1<<20中有很多状态是无效的,所以第一步是选择有效状态,存到cnt[]数组中 二、dp[i][j]表示到第i行的状态cnt[j]所能得到的最大值,状态转移方程dp[i][j] = max(dp[i][j],dp[i-1][k]) ,其中k满足c

Redis中使用布隆过滤器解决缓存穿透问题

一、缓存穿透(失效)问题 缓存穿透是指查询一个一定不存在的数据,由于缓存中没有命中,会去数据库中查询,而数据库中也没有该数据,并且每次查询都不会命中缓存,从而每次请求都直接打到了数据库上,这会给数据库带来巨大压力。 二、布隆过滤器原理 布隆过滤器(Bloom Filter)是一种空间效率很高的随机数据结构,它利用多个不同的哈希函数将一个元素映射到一个位数组中的多个位置,并将这些位置的值置

布隆过滤器的详解与应用

一、什么是Bloom Filter Bloom Filter是一种空间效率很高的随机数据结构,它的原理是,当一个元素被加入集合时,通过K个Hash函数将这个元素映射成一个位阵列(Bit array)中的K个点,把它们置为1。检索时,我们只要看看这些点是不是都是1就(大约)知道集合中有没有它了:如果这些点有任何一个0,则被检索元素一定不在;如果都是1,则被检索元素很可能在。这就是布隆过滤器的基本思

请解释Java Web应用中的前后端分离是什么?它有哪些好处?什么是Java Web中的Servlet过滤器?它有什么作用?

请解释Java Web应用中的前后端分离是什么?它有哪些好处? Java Web应用中的前后端分离 在Java Web应用中,前后端分离是一种开发模式,它将传统Web开发中紧密耦合的前端(用户界面)和后端(服务器端逻辑)代码进行分离,使得它们能够独立开发、测试、部署和维护。在这种模式下,前端通常通过HTTP请求与后端进行数据交换,后端则负责业务逻辑处理、数据库交互以及向前端提供RESTful

通用内存快照裁剪压缩库Tailor介绍及源码分析(一)

背景 我们知道内存快照是治理 OOM 问题及其他类型的内存问题的重要数据源,内存快照中保存了进程虚拟机的完整的堆内存数据,很多时候也是调查其他类型异常的重要参考。但是dump出来的堆转储文件.hprof往往很大,以 LargeHeap 应用为例,其 OOM 时的内存快照大小通常在512M左右,要有效的存储和获取都是一个问题。 线下拿到hprof文件相对容易,也可以预防OOM,但覆盖的场景十分有

.NET 自定义过滤器 - ActionFilterAttribute

这个代码片段定义了一个自定义的 ASP.NET Core 过滤器(GuardModelStateAttribute),用于在控制器动作执行之前验证模型状态(ModelState)。如果模型状态无效,则构造一个 ProblemDetails 对象来描述错误,并返回一个 BadRequest 响应。 代码片段: /// <summary>/// 验证 ModelState 是否有效/// </

特征值分解(EVD)和奇异值分解(SVD)—应用于图片压缩

特征值分解(EVD)和奇异值分解(SVD)—应用于图片压缩 目录 前言 一、特征值分解 二、应用特征值分解对图片进行压缩 三、矩阵的奇异值分解 四、应用奇异值分解对图片进行压缩 五、MATLAB仿真代码 前言         学习了特征值分解和奇异值分解相关知识,发现其可以用于图片压缩,但网上没有找到相应代码,本文在学习了之后编写出了图片压缩的代码,发现奇异值分