一、拦截器 Interceptor
1、什么是拦截器?
拦截器Interceptor是AOP思想的具体应用,是Spring的一个组件,拦截访问Controller中的方法或static文件夹下的静态资源的请求。
2、实现方式
① 自定义一个类实现HandlerInterceptor接口,这个接口中定义了三个方法preHandle、postHandle、afterCompletion,执行顺序为preHandle → Controller中的方法 → postHandle → afterCompletion。所以说在preHandle方法中编写拦截请求后的操作,return true表示放行,return false表示不放行,而postHandle、afterCompletion一般用于记录拦截日志 ;
② 在spring配置文件中进行配置
<!--配置拦截器-->
<mvc:interceptors>
<mvc:interceptor>
<!--配置拦截请求的范围 /**表示所有请求-->
<mvc:mapping path="/**"/>
<!--自定义的拦截器类-->
<bean class="com.etc.config.MyInterceptor"/>
</mvc:interceptor>
</mvc:interceptors>
二、过滤器 Filter
1、什么是过滤器?
过滤器是servlet规范定义的,依赖于Tomcat等容器,是在请求进入容器后进入servlet前对请求进行预处理,比如说编码格式过滤、敏感词过滤等;
2、实现方式
① 自定义一个过滤器类,如EncodingFilter,实现javax.servlet包下的Filter接口
② 在doFilter中编写要进行过滤的操作,然后调用FilterChain的doFilter方法放行,比如说
public void doFilter(ServletRequest req, ServletResponse resp, FilterChain chain) throws IOException, ServletException {
//进行编码格式过滤
req.setCharacterEncoding("UTF-8");
resp.setCharacterEncoding("UTF-8");
resp.setContentType("text/html;charset=UTF-8");
//放行
chain.doFilter(req,resp);
}
③ 在web配置文件中添加过滤器配置
<!--配置过滤器类-->
<filter>
<filter-name>EncodingFilter</filter-name>
<filter-class>com.etc.filter.EncodingFilter</filter-class>
</filter>
<!--配置过滤器映射-->
<filter-mapping>
<filter-name>EncodingFilter</filter-name>
<!--配置过滤请求范围,根据需求调整-->
<url-pattern>/*</url-pattern>
</filter-mapping>
三、参考资料
B站狂神说:过滤器Filter_哔哩哔哩_bilibilihttps://www.bilibili.com/video/BV12J411M7Sj?p=24&vd_source=18add245858bb01410866b08c994e66bB站狂神说:拦截器是什么_哔哩哔哩_bilibilihttps://www.bilibili.com/video/BV1aE41167Tu?p=27&vd_source=18add245858bb01410866b08c994e66b
PS:本文为一名Java初学者的知识整理及备忘,如有错漏,欢迎前辈们指正。