几个参数
order(number) :过滤器的顺序
filterName : 过滤器名称
urlPatterns : 需要过滤的路径
initParams : 初始化参数,存于FilterConfig中
注意
- order 越小越先被经过,即:通过filter的顺序是根据order从小到大依次通过
- 在doFilter()方法中,chain.doFilter()前的一般是对request执行的过滤操作,chain.doFilter()后面的代码一般是对response执行的操作
- 传入的路径参数没有 ’/’ 的含义:没有斜杠表示是相对于当前 Servlet 的路径
例如:请求路径为 http://127.0.0.1/fdemo/filter/test (/fdemo 是上下文)
request.getRequestDispatcher("/page").forward(request,response); // 跳转路径为 http://127.0.0.1/fdemo/page
request.getRequestDispatcher("page").forward(request,response); // 跳转路径为 http://127.0.0.1/fdemo/filter/page
- .forward()方法会直接跳到对应的controller,而不会走后面的Filter
Springboot项目中创建一个Filter
import lombok.extern.slf4j.Slf4j;
import org.springframework.core.annotation.Order;
import javax.servlet.*;
import javax.servlet.annotation.WebFilter;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import java.io.IOException;
@Order(1)
@WebFilter(filterName = "Filter4", urlPatterns = "/*")
@Slf4j
public class Filter4 implements Filter {
/**
* 可以初始化Filter在web.xml里面配置的初始化参数
* filter对象只会创建一次,init方法也只会执行一次。
*/
@Override
public void init(FilterConfig filterConfig) {
log.info("---过滤器的初始化方法!---");
}
/**
* 主要的业务代码编写方法
*/
@Override
public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
HttpServletRequest request = (HttpServletRequest) servletRequest;
HttpServletResponse response = (HttpServletResponse) servletResponse;
String contextPath = request.getContextPath();
String requestURI = request.getRequestURI();
StringBuffer requestURL = request.getRequestURL();
String method = request.getMethod();
String queryString = request.getQueryString();
String servletPath = request.getServletPath();
HttpSession session = request.getSession();
if ("/index".equals(servletPath)){
request.getRequestDispatcher("/page").forward(request,response);
}
log.info("doFilter 之前");
// filterChain.doFilter(servletRequest, servletResponse);
log.info("doFilter 之后");
}
/**
* 在销毁Filter时自动调用。
*/
@Override
public void destroy() {
log.info("---销毁Filter---");
}
}
网友评论