Filter过滤器
过滤器是服务器与客户端请求、响应的中间层组件,在实际项目开发中过滤器主要用于对浏览器的请求进行过滤处理,将过滤后的请求再转给下一个资源。修改请求或响应信息,完成一些通用的功能。
过滤器的使用场景
• 乱码的统一处理,这前我们的POST方法提交汉字会有乱码问题,在每个Servlet中都要进行乱码处理。我们可以在过滤器中,通过一个过滤器处理所有的Servlet乱码问题。
• 对非法的请求进行拦截,如果没有登录的用户,拦截这个请求,不能访问必须要登录才可以访问的资源。
• 过滤非法字符,或不健康文字,使用过滤器进行打码处理等
过滤器执行流程
1、用户发送请求,请求Web资源,如果过滤器发现这个请求地址与过滤的地址匹配,经过过滤器
2、执行过滤器中的doFilter方法,处理过滤器的代码
3、调用chain.doFilter方法进行放行,如果没有调用这个方法,过滤器就拦截了请求。不能到达web资源。
4、访问完过滤器以后,到达web资源,响应回来还会再次经过过滤器。
过滤器生命周期
过滤器生命周期方法
1.init:在服务器启动后,会创建Filter对象,然后调用init方法。只执行一次。用于加载资源
2.doFilter:每一次请求被拦截资源时,会执行。执行多次
3.destroy:在服务器关闭后,Filter对象被销毁。如果服务器是正常关闭,则会执行destroy方法。只执行一次。用于释放资源
过滤器的拦截方式
拦截方式用于指定过滤器在什么样的请求方式下进行拦截,默认是只对直接来自浏览器发送的请求才拦截。
通过注解设置dispatcherTypes属性
1.REQUEST:默认值。浏览器直接请求资源
2.FORWARD:转发访问资源
3.INCLUDE:包含访问资源
4.ERROR:错误跳转资源
5.ASYNC:异步访问资源