项目结构:

AFilter:
package cn.itcast.web.filter;
import javax.servlet.*; import java.io.IOException; public class AFilter implements Filter { /** * init方法在filter创建之后立即执行,用来做初始化 * @param filterConfig * @throws ServletException */ @Override public void init(FilterConfig filterConfig) throws ServletException { System.out.println("过滤器初始化!"); } /** * 每次过滤时都会执行 * @param servletRequest * @param servletResponse * @param filterChain * @throws IOException * @throws ServletException */ @Override public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException { System.out.println("过滤器拦截。。。"); filterChain.doFilter(servletRequest, servletResponse); System.out.println("回来执行doFilter方法。。。"); } /** * destroy方法在销毁之前执行,用来对非内存资源释放 */ @Override public void destroy() { System.out.println("过滤器销毁!"); } }
web.xml配置
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd"
version="3.1">
<servlet>
<servlet-name>AServlet</servlet-name>
<servlet-class>cn.itcast.web.servlet.AServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>AServlet</servlet-name>
<url-pattern>/AServlet</url-pattern>
</servlet-mapping>
<filter>
<filter-name>AFilter</filter-name>
<filter-class>cn.itcast.web.filter.AFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>AFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
</web-app>
index.jsp页面
<%@ page contentType="text/html;charset=UTF-8" language="java" %> <html> <head> <title>Title</title> </head> <body> <%System.out.println("执行index.jsp。。。");%> index.jsp页面 </body> </html>
控制台输出:
项目启动时执行init方法

访问index.jsp,http://localhost:8080/day09/index.jsp
执行doFilter方法

关闭服务器销毁filter

销毁filter之前会调用destroy方法
