概念:
servlet:servlet是一种运行服务器端的java应用程序,具有独立于平台和协议的特性,并且可以动态的生成web页面,它工作在客户端请求与服务器响应的中间层。
filter:filter是一个可以复用的代码片段,可以用来转换HTTP请求、响应和头信息。Filter不像Servlet,它不能产生一个请求或者响应,它只是修改对某一资源的请求,或者修改从某一的响应。
listener:监听器,从字面上可以看出listener主要用来监听只用。通过listener可以监听web服务器中某一个执行动作,并根据其要求作出相应的响应。通俗的语言说就是在application,session,request三个对象创建消亡或者往其中添加修改删除属性时自动执行代码的功能组件。
interceptor:是在面向切面编程的,就是在你的service或者一个方法,前调用一个方法,或者在方法后调用一个方法,比如动态代理就是拦截器的简单实现,在你调用方法前打印出字符串(或者做其它业务逻辑的操作),也可以在你调用方法后打印出字符串,甚至在你抛出异常的时候做业务逻辑的操作。
servlet、filter、listener是配置到web.xml中,interceptor不配置到web.xml中,spring的拦截器配置到spring.xml中。
生命周期
servlet
servlet的生命周期始于它被装入web服务器的内存时,并在web服务器终止或重新装入servlet时结束。servlet一旦被装入web服务器,一般不会从web服务器内存中删除,直至web服务器关闭或重新结束。
- 装入:启动服务器时加载Servlet的实例;
- 初始化:web服务器启动时或web服务器接收到请求时,或者两者之间的某个时刻启动。初始化工作有init()方法负责执行完成;
- 调用:从第一次到以后的多次访问,都是只调用doGet()或doPost()方法;
- 销毁:停止服务器时调用destroy()方法,销毁实例。
filter
filter:(一定要实现javax.servlet包的Filter接口的三个方法init()、doFilter()、destroy(),空实现也行)
- 启动服务器时加载过滤器的实例,并调用init()方法来初始化实例;
- 每一次请求时都只调用方法doFilter()进行处理;
- 停止服务器时调用destroy()方法,销毁实例。
listener
类似于servlet和filter。
web.xml 的加载顺序是:context- param -> listener -> filter -> servlet
(三者的详细区别及加载机制可以参考另一篇://www.greatytc.com/p/612c3a6673b2)
interceptor
以springMVC的拦截器为例,加载了springMVC.xml以后,初始化相应拦截器。当action请求来时调用intercept方法,服务器停止销毁interceptor。
职责
servlet:
创建并返回一个包含基于客户请求性质的动态内容的完整的html页面;
创建可嵌入到现有的html页面中的一部分html页面(html片段);
读取客户端发来的隐藏数据;
读取客户端发来的显示数据;
与其他服务器资源(包括数据库和java的应用程序)进行通信;
通过状态代码和响应头向客户端发送隐藏数据。
filter:
filter能够在一个请求到达servlet之前预处理用户请求,也可以在离开servlet时处理http响应:
在执行servlet之前,首先执行filter程序,并为之做一些预处理工作;
根据程序需要修改请求和响应;
在servlet被调用之后截获servlet的执行
listener:职责如概念。
servlet2.4规范中提供了8个listener接口,可以将其分为三类,分别如下:
第一类:与servletContext有关的listner接口。包括:ServletContextListener、ServletContextAttributeListener
第二类:与HttpSession有关的Listner接口。包括:HttpSessionListner、HttpSessionAttributeListener、HttpSessionBindingListener、 HttpSessionActivationListener;
第三类:与ServletRequest有关的Listener接口,包括:ServletRequestListner、ServletRequestAttributeListener
interceptor:
属于某种扩展servlet的第三方扩展实现(structs、springMVC等)范畴,与过滤器十分相似,通过层层拦截,处理用户的请求和响应,粒度可以更加精确,可以定位到controller。
与filter的主要区别的过滤器和拦截器的区别与联系:
- 拦截器是基于java反射机制的,而过滤器是基于函数回调的。
- 过滤器依赖与servlet容器,而拦截器不依赖与servlet容器。
- 拦截器只能对Action请求起作用,而过滤器则可以对几乎所有请求起作用。
- 拦截器可以访问Action上下文、值栈里的对象,而过滤器不能。
- 在Action的生命周期中,拦截器可以多次调用,而过滤器只能在容器初始化时被调用一次。