SpringBoot下,利用@WebFilter配置使用与注意【转】
Filter简介
Filter也称之为过滤器,它是Servlet技术中最实用的技术,WEB开发人员通过Filter技术,对web服务器管理的所有web资源:例如JSP,Servlet,静态图片文件或静态HTML文件进行拦截,从而实现一些特殊功能。例如实现URL级别的权限控制、过滤敏感词汇、压缩响应信息等一些高级功能。
Filter工作原理
当客户端发出Web资源的请求时,Web服务器根据应用程序配置文件设置的过滤规则进行检查,若客户请求满足过滤规则,则对客户请求/响应进行拦截,对请求头和请求数据进行检查或改动,并依次通过过滤器链,最后把请求/响应交给请求的Web资源处理。请求信息在过滤器链中可以被修改,也可以根据条件让请求不发往资源处理器,并直接向客户机发回一个响应。当资源处理器完成了对资源的处理后,响应信息将逐级逆向返回。同样在这个过程中,用户可以修改响应信息,从而完成一定的任务。
web浏览器-->web服务器-->过滤器-->web资源/jsp/servlet/html |
服务器会按照过滤器定义的先后循序组装成一条链,然后一次执行其中的doFilter()方法。(注:这一点Filter和Servlet是不一样的)执行的顺序就如下图所示,执行第一个过滤器的chain.doFilter()之前的代码,第二个过滤器的chain.doFilter()之前的代码,请求的资源,第二个过滤器的chain.doFilter()之后的代码,第一个过滤器的chain.doFilter()之后的代码,最后返回响应。
SpringBoot利用@WebFilter配置Filter
第一步:利用@WebFilter创建Filter过滤器类
//@Component//无需添加此注解,@WebFilter会自动将此filter加入容器 @WebFilter(urlPatterns = "/lvjia/carbodyad/api/*", filterName = "rest0PubFilter") @Order(1)//指定过滤器的执行顺序,值越大越靠后执行 public class Rest0PubFilter implements Filter { @Override public void init(FilterConfig filterConfig) {//初始化过滤器 System.out.println("getFilterName:"+filterConfig.getFilterName());//返回<filter-name>元素的设置值。 System.out.println("getServletContext:"+filterConfig.getServletContext());//返回FilterConfig对象中所包装的ServletContext对象的引用。 System.out.println("getInitParameter:"+filterConfig.getInitParameter("cacheTimeout"));//用于返回在web.xml文件中为Filter所设置的某个名称的初始化的参数值 System.out.println("getInitParameterNames:"+filterConfig.getInitParameterNames());//返回一个Enumeration集合对象。 } @Override public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException { if(false){ response.sendRedirect("http://localhost:8081/demo/test/login");//重定向 } filterChain.doFilter(servletRequest, servletResponse);//doFilter将请求转发给过滤器链下一个filter , 如果没有filter那就是你请求的资源 } @Override public void destroy() { } }
@WebFilter常用属性
属性 |
类型 |
是否必需 |
说明 |
asyncSupported |
boolean |
否 |
指定Filter是否支持异步模式 |
dispatcherTypes |
DispatcherType[] |
否 |
指定Filter对哪种方式的请求进行过滤。 |
支持的属性:ASYNC、ERROR、FORWARD、INCLUDE、REQUEST; |
|||
默认过滤所有方式的请求 |
|||
filterName |
String |
否 |
Filter名称 |
initParams |
WebInitParam[] |
否 |
配置参数 |
displayName |
String |
否 |
Filter显示名 |
servletNames |
String[] |
否 |
指定对哪些Servlet进行过滤 |
urlPatterns/value |
String[] |
否 |
两个属性作用相同,指定拦截的路径 |
过滤器的urlPatterns的过滤路径规则:
1.全路径匹配: /abc/myServlet1.do
2.部分路径匹配: /abc/*
3.通配符匹配 :/*
4.后缀名匹配 :*.do (注意:前面不加/)
注意:
@WebFilter(urlPatterns = "/lvjia/carbodyad/api/*", filterName = "rest0PubFilter")
filterName的首字母一定要小写!!!小写!!!小写!!!
我因为这个,导致配置的多个过滤器拦截url都失效了!不管啥路径,全给我拦截到Filter里去了
第二步;Application启动类添加@ServletComponentScan注解
@SpringBootApplication @ServletComponentScan //Servlet、Filter、Listener 可以直接通过 @WebServlet、@WebFilter、@WebListener 注解自动注册,无需其他代码。 public class Application { public static void main(String[] args) { SpringApplication.run(Application.class, args); } }
至此,在SpringBoot内利用@WebFilter注解配置过滤器就ok了,确实比较快捷方便,除了@WebFilter方式,还有利用spring 的@Bean配置过滤器的方式,下次再补充进来、。
本文章主要以理解与使用为主,至于Filter的原理问题未进行深入探索,如有问题请及时留言交流。
参考
SpringBoot下,利用@WebFilter配置使用与注意Filter==>https://blog.csdn.net/With_Her/article/details/82627620
Filter和Interceptor理解==>https://www.cnblogs.com/whatlonelytear/p/15067959.html
SpringBoot下,利用@WebFilter配置使用与注意【转】==>https://www.cnblogs.com/whatlonelytear/p/11266233.html