Servlet规范中有3个非常特殊的Servlet,分别是过滤器、监听器和拦截器,如果使用得当,利用它们可以简单地完成一般Servlet才能实现的烦琐功能。下面分别介绍过滤器、监听器和拦截器。
过滤器、监听器和拦截器简介
过滤器(Filter)放在Web资源之前,可以在前端请求抵达Web资源之前被截获,并且还可以在资源返回客户之前截获输出的请求。过滤器是用来拦截请求的,处于客户端与被请求资源之间,目的是重用代码。在一个项目中可以配置多个过滤器,一个请求会依次通过配置的所有过滤器。
Web项目常用的过滤器有以下3种:
用户授权的过滤器:负责检查用户请求,根据请求信息过滤用户的非法请求。
日志过滤器:详细记录某些特殊的用户请求。
负责编码/解码的过滤器:对请求参数的编码和解码。
Java中的过滤器是一种特殊的Servlet,它不能处理用户请求,也不能为客户端生成响应信息,它主要用于对HttpServletRequest进行前处理,也可以对HttpServletResponse进行后处理,是一个典型的处理链程序。
监听器也是一种特殊的Servlet,能够监听Web项目中特定的事件。例如,监听ServletContext、HttpSession和ServlerRequest对象的创建和销毁及各种变量的创建、销毁和修改等,还可以在一些请求前后增加监听处理,实现监听。
监听器的父接口为java.util.EventListener,所有监听器都需要实现此接口。常见的监听器有:HttpSessionListener用来监听Session,ContextLoaderListener是在启动Web容器时自动监听装配ApplicationContext的配置信息&