登陆验证
过滤器
1 | public void doFilter (ServletRequest req, ServletResponse resp, FilterChain chain) throws IOException, ServletException { |
1 | <filter> |
通过path+/jsp/**访问的,没有session访问不了;
在我看来这个就是对静态资源的过滤,我们通过地址的方式无法访问
拦截器
1 | public class loginInterceptor implements HandlerInterceptor { |
1 | <mvc:interceptors> |
==只会拦截我们访问的控制器方法,就是我们的controller里面的request Mapping里面的方法,不会拦截静态资源,减少资源损耗==
拦截器和过滤器的区别
过滤器和拦截器的区别:
*①拦截器是基于java的反射机制的,而过滤器是基于函数回调。
②拦截器不依赖与servlet容器,过滤器依赖与servlet容器。
③拦截器只能对action请求起作用,而过滤器则可以对几乎所有的请求起作用。
④拦截器可以访问action上下文、值栈里的对象,而过滤器不能访问。
⑤在action的生命周期中,拦截器可以多次被调用,而过滤器只能在容器初始化时被调用一次。**
⑥拦截器可以获取IOC容器中的各个bean,而过滤器就不行,这点很重要,在拦截器里注入一个service,可以调用业务逻辑。
\拦截器可以获取ioc中的service bean实现业务逻辑,****拦截器可以获取ioc中的service bean实现业务逻辑,********拦截器可以获取ioc中的service bean实现业务逻辑,******
过滤器和拦截器的区别:
①拦截器是基于java的反射机制的,而过滤器是基于函数回调。
②拦截器不依赖与servlet容器,过滤器依赖与servlet容器。
③拦截器只能对action请求起作用,而过滤器则可以对几乎所有的请求起作用。
④拦截器可以访问action上下文、值栈里的对象,而过滤器不能访问。
⑤在action的生命周期中,拦截器可以多次被调用,而过滤器只能在容器初始化时被调用一次。
⑥拦截器可以获取IOC容器中的各个bean,而过滤器就不行,这点很重要,在拦截器里注入一个service,可以调用业务逻辑。
\⑥拦截器可以获取IOC容器中的各个bean,而过滤器就不行,这点很重要,在拦截器里注入一个service,可以调用业务逻辑。**
⑥拦截器可以获取IOC容器中的各个bean,而过滤器就不行,这点很重要,在拦截器里注入一个service,可以调用业务逻辑。
\⑥拦截器可以获取IOC容器中的各个bean,而过滤器就不行,这点很重要,在拦截器里注入一个service,可以调用业务逻辑。**
\拦截器可以获取ioc中的service bean实现业务逻辑,****拦截器可以获取ioc中的service bean实现业务逻辑,********拦截器可以获取ioc中的service bean实现业务逻辑,******



