基于servlet容器的filter
通过@WebFilter注解注入
@WebFilter(urlPatterns = "/hello")
public class TestFilter implements Filter {
//实现Filter接口中的方法
}
//在启动类上加入@ServletComponentScan注解,使得过滤器被扫描出来
@SpringBootApplication
@ServletComponentScan
public class TestbootApplication {
public static void main(String[] args) {
SpringApplication.run(TestbootApplication.class, args);
}
}
通过@Bean注解注入
创建过滤类:
@Component
public class TestFilter3 implements Filter{
//实现Filter接口中的方法
}
//注册过滤器
@Configuration
public class FilterConfig {
@Bean
public FilterRegistrationBean testFilter3RegistrationBean() {
FilterRegistrationBean registration = new FilterRegistrationBean(new TestFilter3());
registration.addUrlPatterns("/hello");
registration.setOrder(1); // 值越小越靠前,此处配置有效
return registration;
}
}
基于Springboot mvc架构的拦截器(Interceptor)
创建自定义拦截器只需要继承HandlerInterceptor 接口,实现该接口的方法
preHandle() – 在handler执行之前,返回 boolean 值,true 表示继续执行,false 为停止执行并返回。
postHandle() – 在handler执行之后, 可以在返回之前对返回的结果进行修改
afterCompletion() – 在请求完全结束后调用,可以用来统计请求耗时等等
自定义拦截器配置类继承自WebMvcConfigurer,重写addInterceptors将自定义的拦截器添加至注册中心。
WebMvcConfigurer常见用途:
addInterceptors:拦截器
addViewControllers:页面跳转
addResourceHandlers:静态资源
configureDefaultServletHandling:默认静态资源处理器
configureViewResolvers:视图解析器
configureContentNegotiation:配置内容裁决的一些参数
addCorsMappings:跨域
configureMessageConverters:信息转换器
Filter跟Interceptor的区别及执行顺序
- 拦截器(Interceptor)是基于Java的反射机制,而过滤器(Filter)是基于函数回调。从灵活性上说拦截器功能更强大些,Filter能做的事情,都能做,而且可以在请求前,请求后执行,比较灵活。Filter主要是针对URL地址做一个编码的事情、过滤掉没用的参数、安全校验(比较泛的,比如登录不登录之类),太细的话,还是建议用interceptor。不过还是根据不同情况选择合适的
- 两者都是基于AOP思想的实际应用,Filter需要在web.xml中配置,依赖于Servlet容器, Interceptor需要在SpringMVC中配置,依赖于框架
- 拦截器是 AOP 的一种应用,底层采用 Java 的反射机制来实现的。与过滤器一个很大的区别是在拦截器中可以注入 Spring 的 Bean,能够获取到各种需要的 Service 来处理业务逻辑,而过滤器则不行,优先执行Filter再执行Interceptor
扩展
监听器Listner
监听器也叫Listener,是servlet的监听器,可以用于监听Web应用中某些对象,信息的创建,销毁,增加,修改,删除等动作的发生,然后做出相应的响应处理
AOP(切面编程)
用注释@Aspect来实现,表明当前类是一个切面类
@Aspect
@Component
public class LogAspect {
// 切点
@Pointcut("execution(* com.banmoon.blog.controller..*(..))")
public void aspect() {
//环绕通知(@Around):内部执行连接点(方法),对其进行增强
//前置通知(@Before):在执行连接点前执行
//后置通知(@After):在执行连接点后执行
//返回通知(@AfterReturning):在连接点返回后执行
//异常通知(@AfterThrowing):在连接点爆出异常后执行
}
}