filter就是其他框架中的中间件,在SpringBoot
启动时有很多默认加载的Filter
例如:
- characterEncodingFilter
- hiddenHttpMethodFilter
- httpPutFormContentFilter
- requestContextFilter
Filter
存在一个优先级, 数值越小越靠前
这有两个常量用来表顺顺序 Ordered.HIGHEST_PRECEDENCE
Ordered.LOWEST_PRECEDENCE
低位值意味着更高的优先级 Higher values are interpreted as lower priority,自定义Filter
,避免和默认的Filter
优先级一样,不然会冲突
还可以注册Filter
的bean
FilterRegistrationBean
自定义Filter
1)使用Servlet3.0
的注解进行配置
2)启动类里面增加 @ServletComponentScan
,进行扫描
3)新建一个Filter
类,implements Filter
,并实现对应的接口
4) @WebFilter
标记一个类为filter
,被spring
进行扫描
urlPatterns:拦截规则,支持正则
5)控制chain.doFilter
的方法的调用,来实现是否通过放行不放行,web应用res.sendRedirect("/index.html");
进行跳转
场景:权限控制、用户登录等
编写Filter
在启动类文件里面增加注解
@ServletComponentScan
- LoginFilter
package com.example.demo.filter; import org.springframework.core.Ordered; 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 java.io.IOException; /** * urlPatterns 正则匹配路由 * filterName 过滤器名称 */ @WebFilter(urlPatterns = "/api/*", filterName = "loginFilter") @Order(value = 1) public class LoginFilter implements Filter { @Override public void init(FilterConfig filterConfig) throws ServletException { System.out.println("初始化操作"); } @Override public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException { // 有学过其他框架的同志 这个就是中间件 在这里做鉴权、日志等操作 HttpServletRequest req = (HttpServletRequest) request; HttpServletResponse res = (HttpServletResponse) response; String username = req.getParameter("username"); if ("aoppp".equals(username)) { // 如果登录名称 确认就通过 System.out.println("验证通过" + username); chain.doFilter(request, response); } else { // 否则跳转到首页 res.sendRedirect("/error/403.html"); // 跳转到static/error/403.html } } @Override public void destroy() { System.out.println("销毁时触发,一般热更新可以明确看到"); } }
- static/error/403.html
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> </head> <body> <h1>403</h1> </body> </html>
- ApiController
@RequestMapping("/api/v1/login") public Object login(HttpServletRequest request) { Map<String, String> map = new HashMap<>(); map.put("username", request.getParameter("username")); return map; }
效果