目录
简介
过滤器,它是基于sevlet实现的,顾名思义就是对servlet容器中的流程进行过滤,比如对servlet request过滤没有登陆的用户,让其进行登陆等等操作。
原理
通过方法的回调实现的,这是与拦截器Interceptor的本质区别。首先在定义过滤器时需要实现Filter接口,在此需要注意Filter是来自servlet。该接口下主要有三个方法。
init方法
在执行过滤方法之前需要做的一些初始化操作。实例化过滤器后,servlet容器仅调用一次init方法,且在执行过滤方法之前init方法必须完成。
doFilter方法
需要根据业务逻辑编写过滤逻辑,当过滤完成想要接着进行下面的操作那么调用FilterChain的dofilter方法。
destroy方法
在执行完实际的过滤业务逻辑后可以对一些资源进行销毁(释放资源)。
参考代码
package com.king.givenchy.filter;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.annotation.WebFilter;
import java.io.IOException;
@WebFilter(urlPatterns = "/*", filterName = "loginFilter")
public class LoginFilter implements Filter {
private static final Logger LOGGER = LoggerFactory.getLogger(LoginFilter.class);
@Override
public void init(FilterConfig filterConfig) throws ServletException {
LOGGER.info("init.....");
}
@Override
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
//TODO Business logic
LOGGER.info("doFilter.....");
chain.doFilter(request, response);
}
@Override
public void destroy() {
LOGGER.info("destroy.....");
}
}
本文只是对使用过程中的要点进行记录。