JavaWeb 之三大组件Servlet、Listener、Filter
Maven依赖:
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>javax.servlet-api</artifactId>
<version>3.1.0</version>
</dependency>
Servlet
Listener
Filter
滤器是用来拦截请求的,而不是处理请求的。
当用户请求某个Servlet时,会先执行部署在这个请求上的Filter,如果Filter“放行”,那么会继承执行用户请求的Servlet;如果Filter不“放行”,那么就不会执行用户请求的Servlet。
其实可以这样理解,当用户请求某个Servlet时,Tomcat会去执行注册在这个请求上的Filter,然后是否“放行”由Filter来决定。可以理解为,Filter来决定是否调用Servlet!当执行完成Servlet的代码后,还会执行Filter后面的代码。
自定义过滤器:
import javax.servlet.*;
import java.io.IOException;
@WebFilter(filterName = "HelloFilter ", urlPatterns = { "/*" })
public class HelloFilter implements Filter {
@Override
public void init(FilterConfig filterConfig) throws ServletException { }
@Override
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
System.out.println("filter start...");
chain.doFilter(request, response); // 放行
System.out.println("filter end...");
}
@Override
public void destroy() { }
}
在web.xml中配置过滤器:
<filter>
<filter-name>helloFilter</filter-name>
<filter-class>com.mvc.HelloFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>helloFilter</filter-name>
<url-pattern>/index.jsp</url-pattern>
</filter-mapping>
Servlet3.0之后使用注解配置过滤器:
@WebFilter 用于将一个类声明为:过滤器,该注解将会在部署时被容器处理,容器将根据具体的属性配置将相应的类部署为过滤器。该注解具有下表给出的一些常用属性 ( 以下所有属性均为可选属性,但是 value、urlPatterns、servletNames 三者必需至少包含一个,且 value 和 urlPatterns 不能共存,如果同时指定,通常忽略 value 的取值 )。
import javax.servlet.*;
import java.io.IOException;
@WebFilter(filterName = "HelloFilter ", urlPatterns = { "/*" })
public class HelloFilter implements Filter {
@Override
public void init(FilterConfig filterConfig) throws ServletException { }
@Override
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
System.out.println("filter start...");
chain.doFilter(request, response); // 放行
System.out.println("filter end...");
}
@Override
public void destroy() { }
}