面试题 JavaWeb Filter Listener

什么是过滤器?

定义:依赖于servlet容器;
在实现上基于函数回调,可以对几乎所有请求进行过滤;
缺点是一个过滤器实例只能在容器初始化时调用一次;
作用:用来做一些过滤操作,获取想要获取的数据;
在过滤器中修改字符编码;
在过滤器中修改HttpServletRequest的一些参数,包括:过滤低俗文字、危险字符等。

什么是监听器?

定义

实现了javax.servlet.ServletContextListener 接口的服务器端程序;
随web应用的启动而启动;只初始化一次;
随web应用的停止而销毁;

作用

做一些初始化的内容添加工作、设置一些基本的内容、比如一些参数或者是一些固定的对象等等。如SpringMVC的监听器org.springframework.web.context.ContextLoaderListener,实现了SpringMVC容器的加载、Bean对象创建、DispatchServlet初始化等。

什么是拦截器?

依赖于web框架,在SpringMVC中就是依赖于SpringMVC框架;
在实现上基于Java的反射机制,属于面向切面编程(AOP)的一种运用;
缺点是只能对controller请求进行拦截,对其他的一些比如直接访问静态资源的请求则没办法进行拦截处理;

由于拦截器是基于web框架的调用,因此可以使用Spring的依赖注入(DI)进行一些业务操作,同时一个拦截器实例在一个controller生命周期之内可以多次调用。

过滤器和拦截器的区别?

拦截器 过滤器
基于Java反射机制 基于函数回调
不依赖Servlet容器 依赖Servlet容器
只能对action起作用 几乎对所有请求起作用
可以访问action上下文,值栈里的对象 可以访问action上下文,值栈里的对象
在Action生命周期中,拦截器可以多次被调用 过滤器只能在容器初始化时被调用一次
拦截器不能修改request 过滤器可以修改request
拦截器可以调用IOC容器中的各种依赖 过滤器不能调用IOC容器中的各种依赖
拦截器可以详细到每个方法 过滤器只能在请求的前后使用

过滤器主要是过滤出要的东西,如requeset中的信息;拦截器在做安全方面用的比较多,比如终止一些流程

Servlet与Filter的区别?

Filter是一种特别的Servlet,它们的作用是完全不一样的。
Servlet是用来处理请求的
Filter是用来过滤检查请求的

web.xml 的作用?

用于配置Web应用的相关信息
如:监听器(listener)、过滤器(filter)、 Servlet、相关参数、会话超时时间、安全验证方式、错误页面等。

filter的生命周期?

  • 启动服务器时加载过滤器的实例,并调用init()方法来初始化实例;
  • 每一次请求时都只调用方法doFilter()进行处理;
  • 停止服务器时调用destroy()方法,销毁实例。

    需要实现javax.servlet包的Filter接口的三个方法init()、doFilter()、destroy()