过滤器:当訪问一个web资源的时候,过滤器就在你訪问这个web资源的前进行拦截...在放行过后...filter过滤器也能够做一些其它的事情.

编写过滤器的步骤:

1.写一个过滤器类实现filter接口

2.在web.xml文件里进行注冊..

案例1:

(1).过滤器类

package cn.itheima.filter;

import java.io.IOException;

import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse; public class FilterDemo1 implements Filter {
//过滤器初始化的时候调用这种方法
public void init(FilterConfig filterConfig) throws ServletException {
System.out.println("init....");
}
public void doFilter(ServletRequest request, ServletResponse response,
FilterChain chain) throws IOException, ServletException {
System.out.println("过滤....");
//放行
chain.doFilter(request, response);
}
//过滤器对象死亡的时候做的善后工作
public void destroy() {
System.out.println("destory....");
} }

(2).web.xml文件里的配置:

<filter>
<filter-name>FilterDemo1</filter-name>
<filter-class>cn.itheima.filter.FilterDemo1</filter-class>
</filter>
<filter-mapping>
<filter-name>FilterDemo1</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>

(3).编写一个servlet进行測试:

package cn.itheima.servlet;

import java.io.IOException;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse; public class FilterDemo1 extends HttpServlet { public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
response.getWriter().write("Hello world!");
} public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
doGet(request, response);
} }

执行结果:

当我们启动tomcat的时候,载入day14应用完成的时候init方法运行....

当我们訪问FilterDemo1的时候....假设放行即有doFilter()...就会在页面中看到hello world的字样。

假设没有放行。就不会看到...

当关闭tomcat的时候。我们发现destory方法运行....

因此我们能够总结出filter的生命周期:

生命周期:

当server启动时,web应用载入后,马上创建这个web应用中的全部的过滤器,过滤器创建出来后马上调用init方法运行初始化的操作.

创建出来后一直驻留在内存中为兴许的拦截进行服务.每次拦截到请求后都会导致doFilter方法运行.

在server关闭或web应用被移除出容器时,随着web应用的销毁过滤器对象销毁.销毁之前调用destory方法运行善后工作.

案例2:

(1).我们写两个过滤器FilterDemo1和FilterDemo2

package cn.itheima.filter;

import java.io.IOException;

import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse; public class FilterDemo1 implements Filter {
//过滤器初始化的时候调用这种方法
public void init(FilterConfig filterConfig) throws ServletException {
}
public void doFilter(ServletRequest request, ServletResponse response,
FilterChain chain) throws IOException, ServletException {
System.out.println("filterDemo1....before");
chain.doFilter(request, response);
System.out.println("filterDemo1....after");
}
//过滤器对象死亡的时候做的善后工作
public void destroy() {
} }

package cn.itheima.filter;

import java.io.IOException;

import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse; public class FilterDemo2 implements Filter { public void init(FilterConfig filterConfig) throws ServletException {
} public void doFilter(ServletRequest request, ServletResponse response,
FilterChain chain) throws IOException, ServletException {
System.out.println("filterDemo2....before");
chain.doFilter(request, response);
System.out.println("filterDemo2....after");
} public void destroy() {
} }

控制台的打印结果是:

filterDemo1....before

filterDemo2....before

filterDemo2....after

filterDemo1....after



过滤器的运行顺序是依据web.xml文件里的mapping的配置顺序运行的。

同一时候init的方法还能够使用filterConfig来获取配置文件里的信息。这里我就不演示了

最新文章

  1. javascript - 状态模式 - 简化分支判断流程
  2. vim 常用命令逐渐熟悉以及常用的配置记录
  3. linux 下C++查询mysql数据库
  4. 第3章 Linux常用命令(1)_文件处理命令
  5. code vs1706 求合数和(数论 素数的判定)
  6. xml 嵌入式资源
  7. 如何停止Android Monkey脚本
  8. 设置配置文件信息时的classpath
  9. bzoj4096 [Usaco2013 dec]Milk Scheduling
  10. poj1338
  11. 武汉新芯:已建成IP体系,欲以存储器为特色
  12. 解决failed to push some refs to
  13. Oracle存储过程和自定义函数
  14. 我带着小程序和Springboot后端终于战胜了WebSocket!!!胜利( •̀ ω •́ )y
  15. keras04 - 阿狗阿猫识别 面向对象编程
  16. Python使用Plotly绘图工具,绘制气泡图
  17. Java课程----自我介绍
  18. 设计模式C++学习笔记之十八(Visitor访问者模式)
  19. Error: Could not find gradle wrapper within Android SDK. Might need to update your Android SDK - Android
  20. ubuntu14安装mantis实践(包含LAMP/PHP)

热门文章

  1. Manarcher 求 字符串 的最长回文子串 【记录】
  2. mysql 免安装配置 数据库修改密码和远程IP登陆
  3. nodejs免费空间
  4. 将字符串序列化Object格式
  5. 今天,你Try-Catch了吗?
  6. 微信小程序实现图片双滑缩放大小
  7. localStorage、sessionStorage、cookie、session
  8. https://blog.csdn.net/sxf359/article/details/71082404
  9. rem 自适应布局 bootstrap 移动端适配
  10. CF992E Nastya and King-Shamans_线段树