加载执行顺序

context-param->listener->filter->servlet

web.xml中元素执行的顺序listener->filter->struts拦截器->servlet。

1.过滤器的概念

Java中的Filter 并不是一个标准的Servlet ,它不能处理用户请求,也不能对客户端生成响应。 主要用于对HttpServletRequest 进行预处理,也可以对HttpServletResponse 进行后处理,是个典型的处理链。

优点:过滤链的好处是,执行过程中任何时候都可以打断,只要不执行chain.doFilter()就不会再执行后面的过滤器和请求的内容。而在实际使用时,就要特别注意过滤链的执行顺序问题

2.过滤器的作用描述

  • 在HttpServletRequest 到达Servlet 之前,拦截客户的HttpServletRequest 。
  • 根据需要检查HttpServletRequest ,也可以修改HttpServletRequest 头和数据。
  • 在HttpServletResponse 到达客户端之前,拦截HttpServletResponse 。
  • 根据需要检查HttpServletResponse ,可以修改HttpServletResponse 头和数据。

3.过滤器的执行流程

4.Filter接口

1.如何驱动

在 web 应用程序启动时,web 服务器将根据 web.xml 文件中的配置信息来创建每个注册的 Filter 实例对象,并将其保存在服务器的内存中

2.方法介绍

    • init()  Init 方法在 Filter 生命周期中仅执行一次,web 容器在调用 init 方法时
    • destory()  在Web容器卸载 Filter 对象之前被调用。该方法在Filter的生命周期中仅执行一次。在这个方法中,可以释放过滤器使用的资源。
    • doFilter() Filter 链的执行

5.FilterChain接口

1.如何实例化

代表当前 Filter 链的对象。由容器实现,容器将其实例作为参数传入过滤器对象的doFilter()方法中

2.作用

调用过滤器链中的下一个过滤器

filter实例:

web.xml配置

  1. <!-- 编码过滤器 -->
  2. <filter>
  3. <filter-name>setCharacterEncoding</filter-name>
  4. <filter-class>com.company.strutstudy.web.servletstudy.filter.EncodingFilter</filter-class>
  5. <init-param>
  6. <param-name>encoding</param-name>
  7. <param-value>utf-8</param-value>
  8. </init-param>
  9. </filter>
  10. <filter-mapping>
  11. <filter-name>setCharacterEncoding</filter-name>
  12. <url-pattern>/*</url-pattern>
  13. </filter-mapping>
  14. <!-- 请求url日志记录过滤器 -->
  15. <filter>
  16. <filter-name>logfilter</filter-name>
  17. <filter-class>com.company.strutstudy.web.servletstudy.filter.LogFilter</filter-class>
  18. </filter>
  19. <filter-mapping>
  20. <filter-name>logfilter</filter-name>
  21. <url-pattern>/*</url-pattern>
  22. </filter-mapping>

编码拦截器:

  1. public class EncodingFilter implements Filter {
  2. private String encoding;
  3. private Map<String, String> params = new HashMap<String, String>();
  4. // 项目结束时就已经进行销毁
  5. public void destroy() {
  6. System.out.println("end do the encoding filter!");
  7. params=null;
  8. encoding=null;
  9. }
  10. public void doFilter(ServletRequest req, ServletResponse resp,
  11. FilterChain chain) throws IOException, ServletException {
  12. //UtilTimerStack.push("EncodingFilter_doFilter:");
  13. System.out.println("before encoding " + encoding + " filter!");
  14. req.setCharacterEncoding(encoding);
  15. // resp.setCharacterEncoding(encoding);
  16. // resp.setContentType("text/html;charset="+encoding);
  17. chain.doFilter(req, resp);
  18. System.out.println("after encoding " + encoding + " filter!");
  19. System.err.println("----------------------------------------");
  20. //UtilTimerStack.pop("EncodingFilter_doFilter:");
  21. }
  22. // 项目启动时就已经进行读取
  23. public void init(FilterConfig config) throws ServletException {
  24. System.out.println("begin do the encoding filter!");
  25. encoding = config.getInitParameter("encoding");
  26. for (Enumeration e = config.getInitParameterNames(); e
  27. .hasMoreElements();) {
  28. String name = (String) e.nextElement();
  29. String value = config.getInitParameter(name);
  30. params.put(name, value);
  31. }
  32. }
  33. }

日志拦截器:

  1. public class LogFilter implements Filter {
  2. FilterConfig config;
  3. public void destroy() {
  4. this.config = null;
  5. }
  6. public void doFilter(ServletRequest req, ServletResponse res,
  7. FilterChain chain) throws IOException, ServletException {
  8. // 获取ServletContext 对象,用于记录日志
  9. ServletContext context = this.config.getServletContext();
  10. //long before = System.currentTimeMillis();
  11. System.out.println("before the log filter!");
  12. //context.log("开始过滤");
  13. // 将请求转换成HttpServletRequest 请求
  14. HttpServletRequest hreq = (HttpServletRequest) req;
  15. // 记录日志
  16. System.out.println("Log Filter已经截获到用户的请求的地址:"+hreq.getServletPath() );
  17. //context.log("Filter已经截获到用户的请求的地址: " + hreq.getServletPath());
  18. try {
  19. // Filter 只是链式处理,请求依然转发到目的地址。
  20. chain.doFilter(req, res);
  21. } catch (Exception e) {
  22. e.printStackTrace();
  23. }
  24. System.out.println("after the log filter!");
  25. //long after = System.currentTimeMillis();
  26. // 记录日志
  27. //context.log("过滤结束");
  28. // 再次记录日志
  29. //context.log(" 请求被定位到" + ((HttpServletRequest) req).getRequestURI()
  30. //      + "所花的时间为: " + (after - before));
  31. }
  32. public void init(FilterConfig config) throws ServletException {
  33. System.out.println("begin do the log filter!");
  34. this.config = config;
  35. }
  36. }

HelloServlet类:

  1. public class HelloWorldServlet extends HttpServlet{
  2. /**
  3. * 查看httpservlet实现的service一看便知,起到了一个controll控制器的作用(转向的)
  4. * 之后便是跳转至我们熟悉的doget,dopost等方法中
  5. */
  6. @Override
  7. protected void service(HttpServletRequest req, HttpServletResponse resp)
  8. throws ServletException, IOException {
  9. System.out.println("doservice..."+this.getInitParameter("encoding"));
  10. super.service(req, resp);
  11. }
  12. @Override
  13. protected void doGet(HttpServletRequest req, HttpServletResponse resp)
  14. throws ServletException, IOException {
  15. System.out.println("doget...");
  16. doPost(req, resp);
  17. }
  18. @Override
  19. protected void doPost(HttpServletRequest req, HttpServletResponse resp)
  20. throws ServletException, IOException {
  21. System.out.println("dopost...");
  22. }
  23. }

结果:

  1. before encoding utf-8 filter!
  2. before the log filter!
  3. Log Filter已经截获到用户的请求的地址:/hello
  4. doservice...UTF-8
  5. doget...
  6. dopost...
  7. after the log filter!
  8. after encoding utf-8 filter!
  9. ----------------------------------------

总结:

1.过滤器执行流程

2.常用过滤器

    1. <pre name="code" class="plain"><pre></pre><pre name="code" class="plain"></pre><pre></pre>
    2. <pre></pre>
    3. <pre></pre>
    4. <pre></pre>
    5. <pre></pre>
    6. <pre></pre>
    7. <pre></pre>
    8. </pre>

Servlet中的过滤器Filter详解的更多相关文章

  1. java Servlet中的过滤器Filter

    web.xml中元素执行的顺序listener->filter->struts拦截器->servlet. 1.过滤器的概念 Java中的Filter 并不是一个标准的Servlet ...

  2. Servlet中的过滤器Filter用法

    1.过滤器的概念 Java中的Filter 并不是一个标准的Servlet ,它不能处理用户请求,也不能对客户端生成响应. 主要用于对HttpServletRequest 进行预处理,也可以对Http ...

  3. Servlet中的过滤器Filter

    链web.xml中元素执行的顺序listener->filter->struts拦截器->servlet. 1.过滤器的概念 Java中的Filter 并不是一个标准的Servlet ...

  4. java Web 过滤器Filter详解

    简介 Filter也称之为过滤器,Web开发人员通过Filter技术,对web服务器管理的所有web资源:例如Jsp, Servlet, 静态图片文件或静态 html 文件等进行拦截,从而实现一些特殊 ...

  5. Servlet中Web.xml配置详解(二)

    5.2 分配JSP初始化参数给JSP页面提供初始化参数在三个方面不同于给servlet提供初始化参数.1)使用jsp-file而不是servlet-class.因此,WEB-INF/web.xml文件 ...

  6. servlet中web.xml配置详解

    Web.xml常用元素 <web-app> 所有部署描述符文件的顶层(根)元素 <display-name></display-name>定义了WEB应用的名字 & ...

  7. HBase(0.96以上版本)过滤器Filter详解及实例代码

    说明: 本文参考官方Ref Guide,Developer API和众多博客,并结合实测代码编写,详细总结HBase的Filter功能,并附上每类Filter的相应代码实现. 本文尽量遵从Ref Gu ...

  8. java web之Filter详解

    java web之Filter详解 2012-10-20 0 个评论 作者:chenshufei2 收藏 我要投稿 .概念: Filter也称之为过滤器,它是Servlet技术中比较激动人心的技术,W ...

  9. Spring Security Filter详解

    Spring Security Filter详解 汇总 Filter 作用 DelegatingFilterProxy Spring Security基于这个Filter建立拦截机制 Abstract ...

随机推荐

  1. Vue.js自定义指令的用法与实例

    市面上大多数关于Vue.js自定义指令的文章都在讲语法,很少讲实际的应用场景和用例,以致于即便明白了怎么写,也不知道怎么用.本文不讲语法,就讲自定义指令的用法. 自定义指令是用来操作DOM的.尽管Vu ...

  2. 黑客常用的windows注册表大全

    目录 使系统没有"运行"选项                        1让操作系统无"关闭系统" 选项                    2让操作系统 ...

  3. HTML5常用标签分类

    1.行级元素标签:a.span.sup.sub.em.b.big.i.strong 2.块元素标签:div.p.h1~h6.ul.ol.li.table.form.article.footer.hea ...

  4. flask蓝图的使用

    首先,我对蓝图的理解相对通俗,就是觉得蓝图对于视图方法模块化.大项目协同开发过程中的一个很好的工具. 1.下图是我们通常情况下使用的项目组织结构

  5. 如何利用express新建项目(上)

    如何利用express新建项目(上) 摘要 这篇文章将讲解了如何快速利用express新建项目 一.express4.x的安装 1. npm install -g express 2. npm ins ...

  6. MongoDB基础之六 索引

    一 . 索引概述和基本操作 1. 索引提高查询速度,降低写入速度,权衡常用的查询字段,不必在太多列上建索引2. 在mongodb中,索引可以按字段升序/降序来创建,便于排序3. 默认是用btree来组 ...

  7. 利用 UltraEdit 重新排版 XML 结构数据

    我们在工作常碰到这种情况,通讯数据或文件数据是以 XML 结构形式保存的,但通常 XML 结构比较混乱,不易分析.现在我们利用 UltraEdit32对该类型数据做 Reformat,具体操作如下: ...

  8. TCP/IP 协议族的简介

    TCP/IP重要的特性就是分层.TCP/IP 按照层次分为四层:应用层.传输层.网络层.数据链路层.分层的好处就是当某些地方需要改变的时候,只需要将改变的层替换掉即可,而不用去把整体做替换.各层之间的 ...

  9. .NET 即时通信,WebSocket服务端实例

    即时通信常用手段 1.第三方平台 谷歌.腾讯 环信等多如牛毛,其中谷歌即时通信是免费的,但免费就是免费的并不好用.其他的一些第三方一般收费的,使用要则限流(1s/限制x条消息)要么则限制用户数. 但稳 ...

  10. LoRaWAN协议(七)--完整数据流程

    以下的GW指Gateway 所用指令: root@lora-iot-sk:~# tcpdump -i lo -nn -x 'length>100' 入网流程 GW -> NS join_r ...