Spring Boot 配置过滤器Filter及控制多个Filter的执行顺序

1、实现javax.servlet包下的Filter接口
2、@Component和@Order(可选,有多个过滤器时可添加)注解,@Order用于控制过滤器的级别,值越小级别越高
3、过滤的业务逻辑写在doFilter()方法中。

https://blog.csdn.net/wanping321/article/details/81559477

创建多个过滤器时,如果有两个以上过滤器的过滤规则相同,那么这些过滤器的执行顺序如何呢?
答案是根据我们在web.xml中声明的先后顺序进行执行,也就是先声明的先执行,后声明的后执行。

  本篇属于附加篇,在之前的总结中给大家提到过一个关于登录状态验证的效果,当时是通过Session对象完成的,今天我查了一下,JSP为我们封装了一个用于过滤用的过滤器类Filter,通过它我们就可以非常轻松的完成之前的那个功能了,而且可以在很多地方使用,非常实用。废话不多说,下面开始简单为大家介绍一下JSP提供的过滤器类。

 1、过滤器简介:

  过滤器是什么?过滤器就是根据过滤规则对过滤源进行过滤,然后得到过滤结果。Web过滤器的是什么呢?首先Web过滤器的过滤源是用户的各种请求,过滤规则是开发人员实现制定好的,过滤结果是响应。如何理解呢?大家应该都有这样的经历,当我们想下载一个资源时,如果没有登录,这是系统就会弹出登录窗口强制我们登录;而当我们已经登录后,我们单击下载时,便不会出现强制我们登录的页面。这便是今天我们要一起学习的Web拦截器知识。

 2、过滤器的工作原理:

  

 3、过滤器的生命周期:

  

  过滤器的初始化,我们将我们的工程添加到Tomcat后,当启动Tomcat后,系统便立即会调用过滤器的init()方法,也就是我们的工程一旦部署,我们在项目的添加的过滤器便立刻开始工作。当我们关闭Tomcat时,我们的过滤器会调用destroy()方法,结束我们的过滤监听。

 4、探究过滤器的工作原理:

  a、创建过滤器对象类:

public class firstFilter implements Filter {

    public void destroy() {
System.out.println("Destory-----first");
} public void doFilter(ServletRequest request, ServletResponse response,
FilterChain arg) throws IOException, ServletException {
System.out.println("start-----first");
arg.doFilter(request, response);//没有该方法,页面将一直处于加载状态。
System.out.println("end-----first");
} public void init(FilterConfig arg0) throws ServletException {
System.out.println("Init-----first");
} }

 该类需要实现javax.servlet.Filter接口:   

  

  b、web.xml文件声明:

<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.5" xmlns="http://java.sun.com/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"> <!-- 过滤器对象声明 -->
<filter>
<filter-name>firstFilter</filter-name><!-- 过滤器名 -->
<filter-class>cn.imcook.filter.firstFilter</filter-class><!-- 指定我们新建的过滤器对象的地址 -->
</filter>
<!-- 过滤规则声明 -->
<filter-mapping>
<filter-name>firstFilter</filter-name><!-- 指定规则对于的过滤器对象 -->
<url-pattern>/*</url-pattern><!-- *:代表所有的请求 -->
<dispatcher>REQUEST</dispatcher><!-- 该处有四个值可选,默认是REQUEST -->
</filter-mapping> <welcome-file-list>
<welcome-file>index.jsp</welcome-file>
</welcome-file-list>
<login-config>
<auth-method>BASIC</auth-method>
</login-config>
</web-app>

 这样一行行写代码,很不方便,myeclipse为我们提供了窗口化操作,请看下面的步骤:

  打开我们的web.xml文件,点击Design,进入窗口操作界面:

  

  点击左侧的Filter,先添加一个过滤器对象:

  

  然后再点击Filter,添加该过滤器的规则声明(Filter Mapping):

  

 5、启动Tomcat,在地址浏览器地址栏输入我们的工程名(例如:http://localhost:8080/HelloWord/index.jsp),观察myeclipse控制台的输出。

  ·

  以上便是我们对Filter生命周期的探究。

 6、过滤重定向:

  在这里我们只需要在我们创建的Filter类中稍作修改就可以完成了,那如何修改呢?我只需要在我们的doFilter()方法中添加一个重定向就可以了。

public class loginFilter implements Filter {

    public void destroy() {
System.out.println("Destroy");
} public void doFilter(ServletRequest arg0, ServletResponse arg1,
FilterChain arg2) throws IOException, ServletException {
System.out.println("start-----doFilter"); //arg2.doFilter(arg0, arg1); //重定向
HttpServletRequest requst = (HttpServletRequest)arg0;
HttpServletResponse response = (HttpServletResponse)arg1;
response.sendRedirect(requst.getContextPath()+"/Login.jsp"); System.out.println("end------doFilter");
} public void init(FilterConfig arg0) throws ServletException {
System.out.println("Init");
} }

对于JSP中关于过滤器的知识,就先为大家总结到这里,如果你对过滤器知识很感兴趣,请持续关注博客。下一篇:对个过滤器执行顺序

http://www.cnblogs.com/AndroidJotting/p/4351454.html

JSP网站开发基础总结《九》(转)的更多相关文章

  1. JSP网站开发基础总结《二》

    有了上一篇的学习,我相信大家对于JSP一定有了一定的认识,从今天开始我们真正开启JSP模式,如果你有HTML的基础,那学起JSP来也就方便了很多了,首先JSP做为网站开发语言,它与HTML有很多相似的 ...

  2. JSP网站开发基础总结《一》

    经过JAVASE的学习相信大家对JAVA已经不再陌生,那么JAVA都可以干什么呢?做算法.应用程序.网站开发都可以,从今天开始为大家奉上JAVAEE之JSP动态网站开发基础总结. 既然是动态网站开发, ...

  3. JSP网站开发基础总结《八》

    JSP的学习总结到本篇已经八篇了,内容比较多,但都是实战,本篇最后为大家介绍一个小效果:百度分页.就是当我们遍历的数据对象较多时,这时我们就会看到了这个效果了,那他是如何实现的呢?下面我们就一起学习一 ...

  4. JSP网站开发基础总结《九》

    本篇属于附加篇,在之前的总结中给大家提到过一个关于登录状态验证的效果,当时是通过Session对象完成的,今天我查了一下,JSP为我们封装了一个用于过滤用的过滤器类Filter,通过它我们就可以非常轻 ...

  5. JSP网站开发基础总结《十二》

    前两篇已经简单为大家介绍了一下,有关Filter接口的知识,本篇就让我们以一个登录小功能,来具体实现一下过滤器的作用,便于大家掌握.具体为大家介绍一下如何使用Filter对访问进行过滤,及如何防止中文 ...

  6. JSP网站开发基础总结《四》

    经过前几篇的摸爬滚打,下面我们就开始我们真正的数据库操作了,本篇重点在于如何在网站端编写数据库操作语句,内容不多,就是我们常见的增删改查. 0.数据库对象创建: 在JAVASE基础知识总结时,就为大家 ...

  7. JSP网站开发基础总结《十三》

    继上一篇为大家补充过滤器类后,本篇为大家简单介绍一下如何实现验证码效果.验证码的作用是什么呢?1.防止恶意注册2.防止恶意提交3.防止盗取账户等等,总的来说验证码的存在就是为了,防止非人为的操作,不过 ...

  8. JSP网站开发基础总结《七》

    按照计划本篇将为大家总结搜索功能的两种实现:确定搜索与模糊搜索.所谓精确搜索便是指,根据用户的输入的搜索内容,在数据库中寻找具有一一对应的关系的数据,一般都是用户在数据库中的主键值.而模糊搜索,是一种 ...

  9. JSP网站开发基础总结《六》

    对于本篇需要总结的内容,量估计有点大,大家好好看哈,绝对全是干货,代码的已经运行测试,不存在问题,大家可以参考学习,下面开始本篇的内容. 1.添加数据到数据库: 如何用户在JSP页面的填写的信息输入到 ...

随机推荐

  1. CodeForce 439C Devu and Partitioning of the Array(模拟)

     Devu and Partitioning of the Array time limit per test 1 second memory limit per test 256 megabytes ...

  2. 网页 css

    css---- 层叠样式表(Cascading Style Sheet) 一,层叠样式表的分类 1,外部样式表:在外部定义样式表,然后在页面head里面附加该样式表 2,内嵌样式表:直接在网页head ...

  3. Servlet的学习之Response响应对象(1)

    在之前学习了Servlet中的主体结构,包括Servlet的生命周期方法,和非生命周期方法能获取的一些非常重要的对象如ServletConfig.ServletContext对象等,而从这篇开始我们将 ...

  4. Tomcat详细用法学习(四)

    本篇接上一篇<Tomcat详细用法学习(三)>,主要讲解配置虚拟主机.打包web应用成war包和Tomcat的体系结构 对于Tomcat服务器,可以放置多个网站(多个web应用),这就是讲 ...

  5. Indy10.2.5的危险做法

    为了排查一个Bug今天无意看了看Indy源码,结果吓了一跳.TIdIOHandler.ReadLongWord函数用于读取通讯数据并转换成LongWord类型返回,它做用了一种危险的做法可能会导致数据 ...

  6. HTML5,微信开发原码社区

    HTML5开发助手,快速查看HTML及javascript接口文档 http://www.9miao.com/thread-60966-1-1.html 简洁的手机wap公司产品展示网站模板下载htm ...

  7. JavaScript函数节流与函数去抖

    介绍 首先解释一下这两个概念: 函数节流(throttle):是让一个函数无法在很短的时间间隔内连续调用,当上一次函数执行后过了规定的时间间隔,才能进行下一次该函数的调用. 函数去抖(debounce ...

  8. XML学习经验实例总结2

    DTD约束 Book.dtd: <!ELEMENT 书架 (书+)> <!ELEMENT 书 (书名,价格,介绍)> <!ELEMENT 书名 (#PCDATA)> ...

  9. qsettings 保存自定义结构体(QVariant与自定义结构体相互转化)

    参考博文:QVariant与自定义数据类型转换的方法. 这里摘取其关键内容: 1.将自定义数据类型使用Q_DECLARE_METATYPE宏进行声明,便于编译器识别. 2.在插入对象的时候,声明QVa ...

  10. php数组转xml的递归实现

    原文:php数组转xml的递归实现 PHP中奖数组转为xml的需求是常见的,而且实现方法也有很多种,百度找了一下各种实现方法,但是基本是借组一些组件啥的.我就自己写了一个字符串拼组的方法,支持多维数组 ...