1. Filter简介:
             Filter翻译为中文是过滤器的意思。
             Filter是JavaWeb的三大web组件之一:Servlet、Filter、Listener
             Filter的作用是在请求到达WEB资源(HTML、CSS、Servlet、JSP)之前进行拦截
             Filter需要交给Tomcat访问器管理
     Filter的作用:
             1.Filter可以在请求到达目标资源之前进行拦截
             2.Filter也可以放行请求
             3.Filter可以在响应到达浏览器之前做一个预处理(和servlet不一样的地方)
  2. 配置Filter:
             1.创建一个类实现Filter接口
             2.在web.xml文件中对Filter进行配置
              
  3. Filter的生命周期
                一个请求的发送,到响应返回是一个线程。
                Filter的生命周期,指的是Filter对象由被创建到被销毁的过程
                Filter的生命周期方法:
                    构造器:Filter的构造器在服务器启动时调用。 构造器只会调用一次,说明Filter也是单例多线程的。
                    init():在构造器被调用后,紧接着被调用。作用:用来初始化Filter。
                    doFilter():每一次拦截请求时都会调用。
                            参数:
                                    ServletRequest request  请求报文
                                    ServletResponse respons 响应报文
                                    FilterChain chain  该对象的作用就是放行请求:
                                    可以通过 chain.doFilter(request,response) 放行请求。
                                    当调用chain.doFilter()就相当于调用目标的资源的service方法。

destroy方法在项目停止时调用,用来在对象被销毁前做一些收尾工作。

4.  配置filter时的url-pattern的规则:

(暂时无图)

1.精确匹配:只有当目标资源的地址和url-pattern的地址一模一样时,Filter才会拦截资源
                                                 例子:/2.jsp , 只有当浏览器访问项目根目录下的2.jsp时,才会调用Filter
                           2.路径匹配:当访问的资源在url-pattern配置的路径下时,Filter就会拦截资源。
                                                 例子1:/hello/* , 只要访问项目根目录下hello下的资源,就会调用Filter。
                                                 例子2:/* , 会拦截项目根目录下所有资源
                           3.后缀匹配:只要访问的资源地址和url-pattern的后缀一样就会调用Filter
                                                 例子:*.jsp 只要是以jsp结尾的请求都会拦截
   
                           特殊!!!当使用Filter拦截一个Servlet时,可以将Filter的url-pattern和Servlet的url-pattern一样这样Filter就会拦截发送到Servlet的请求。 也可以通过在

filter-mapping中添加一个servlet-name标签来设置要拦截的Servlet的name

5. Filter的执行顺序
                           我们可以为一个资源设置多个过滤器,当我们为一个资源设置了多个过滤器时,这些过滤器就组成一个Filter链的结构。
                           当我们去掉用chain.doFilter(),如果该过滤器后边还有其他的过滤,相当于调用了下一个过滤器doFilter()方法,如果过滤器后没有其他的过滤器,我们调用chain.doFilter()相当于调用了目标资源的service()方法。
                           多个Filter的执行顺序,有filter-mapping标签的配置顺序决定,filter-mappint靠前,则filter先执行,靠后则后执行。
                           我们可以通过修改filter-mapping的顺序来修改Filter的执行顺序


         6.  HttpFilter
                           仿写HttpFilter,仿写和HttpServlet一致!

(暂时无图)

7.  dispatcher
                            Filter默认只会拦截直接向目标资源发送的请求,而像转发之类的请求不会拦截,但是可以在在filter-mapping的dispatcher标签中来指定过滤器要拦截的请求类型。

<dispatcher>REQUEST</dispatcher>
                            代表拦截发送到目标资源的直接请求,如果不指定dispatcher默认值就是REQUEST
                            <dispatcher>FORWARD</dispatcher>
                            FORWARD代表会拦截通过转发访问目标资源的请求。
                            <dispatcher>INCLUDE</dispatcher>
                            INCLUDE会拦截动态包含的请求。
                            <dispatcher>ERROR</dispatcher>
                            ERROR是拦截在web.xml中声明的错误页面的
                                我们可以在web.xml文件进行一个错误页面的映射,通过如下标签:
                                  <error-page>
                                    <error-code>404</error-code>
                                   <location>/4.jsp</location>
                                 </error-page>
                            error-code指的是发生错误的代码
                            location 发生错误以后去到的页面

170815-关于Filter的知识点的更多相关文章

  1. filter的知识点 和 实例

    一.过滤器Filter 1.filter的简介 filter是对客户端访问资源的过滤,符合条件放行,不符合条件不放行,并且可以对目    标资源访问前后进行逻辑处理 2.快速入门 步骤: 1)编写一个 ...

  2. stark - filter、pop、总结

    一.filter 效果图 知识点 1.配置得显示Filter,不配置就不显示了 list_filter = ['title','publish', 'authors'] 2.前端显示 后端返回 字典 ...

  3. django 操作数据库--orm(object relation mapping)---models

    思想 django为使用一种新的方式,即:关系对象映射(Object Relational Mapping,简称ORM). PHP:activerecord Java:Hibernate C#:Ent ...

  4. servlet filter listener interceptor 知识点

    这篇文章主要介绍 servlet filter listener interceptor 之 知识点.博文主要从 概念,生命周期,使命介绍其区别.详情如下:   概念 生命周期 使命 servlet ...

  5. django查询中模糊的知识点,filter(blog=blog),filter(username=username).first()--这两者只需一招让你分清QuerySet对象,和用户字典对象

    只需一招让你分清QuerySet对象,和用户字典对象 article_list = models.Article.objects.filter(blog=blog) user_obj = models ...

  6. ASP.NET Core 中的那些认证中间件及一些重要知识点

    前言 在读这篇文章之间,建议先看一下我的 ASP.NET Core 之 Identity 入门系列(一,二,三)奠定一下基础. 有关于 Authentication 的知识太广,所以本篇介绍几个在 A ...

  7. ASP.NET MVC开发:Web项目开发必备知识点

    最近加班加点完成一个Web项目,使用Asp.net MVC开发.很久以前接触的Asp.net开发还是Aspx形式,什么Razor引擎,什么MVC还是这次开发才明白,可以算是新手. 对新手而言,那进行A ...

  8. 【干货分享】前端面试知识点锦集02(CSS篇)——附答案

    二.CSS部分 1.解释一下CSS的盒子模型? 回答一:a.标准的css盒子模型:宽度=内容的宽度+边框的宽度+加上内边具的宽度b.网页设计中常听的属性名:内容(content).填充(padding ...

  9. [转]ASP.NET Core 中的那些认证中间件及一些重要知识点

    本文转自:http://www.qingruanit.net/c_all/article_6645.html 在读这篇文章之间,建议先看一下我的 ASP.NET Core 之 Identity 入门系 ...

随机推荐

  1. OSPF与ACL 综合应用

    1.企业内网运行OSPF路由协议,区域规划如图所示:2.财务和研发所在的区域不受其他区域链路不稳定性影响:3.R1.R2.R3只允许被IT登录管理:4.YF和CW之间不能互通,但都可以与IT互通:5. ...

  2. Docker Compose 部署 Redis 及原理讲解 | 懒人屋

    原文:Docker Compose 部署 Redis 及原理讲解 | 懒人屋 Docker Compose 部署 Redis 及原理讲解  4.4k  字    16  分钟    2019-10-1 ...

  3. ssm中web配置各框架的配置文件路径方式

    一.在web文件中配置 使用逗号隔开 二.在applicationContext.xml文件中配置或引用 以下是引用方式 注: <import />标签要放在所有bean配置的最前面.  

  4. ES6中class的实现原理

    一.在ES6以前实现类和继承 实现类的代码如下: function Person(name, age) { this.name = name; this.age = age; } Person.pro ...

  5. Spring基础12——使用外部属性文件

    1.使用外部属性文件 在配置文件里配置Bean时,有时需要在Bean的配置文件里引入系统部署的细节信息(例如:文件的路径.数据源配置信息等),而这些部署细节实际上需要和bean配置相分离,因为我们修改 ...

  6. Spring基础06——依赖注入的一些细节

    1.字面值 可用字符串表示的值,可以通过<value>元素标签或value属性进行注入.基本数据类型及其封装类,String类等类型都可以采取字面值注入的方式.若字面值包含特殊字符,可以使 ...

  7. nice - 改变执行程序的优先级

    总览 (SYNOPSIS) nice [OPTION]... [COMMAND [ARG]...] 描述 (DESCRIPTION) 以 调整过的 调度优先级 运行 COMMAND. 如果 没给出 C ...

  8. 关于Mysql group by 的记录

    对于有group by 字段的select语句,group by 后面的字段如果没有出现在组函数里(max,min,sum,avg, count等),则一定要出现在select后面的字段里, 否则会报 ...

  9. Schematic - "DesignEntry 30 ERROR Instance referencing symbol is out of date"

    Schematic - "DesignEntry 30 ERROR Instance referencing symbol is out of date"     Descript ...

  10. Linux文件的操作及授权

    需求1:新建除了root之外的新用户,并且新用户具有root用户的相关功能 1.首先修改/etc/sudoers文件具有写入的权限 chmod 777 /etc/sudoers 2.修改/etc/su ...