1. JavaWeb中的监听器Listener
我们按照监听模型来梳理一下三大关键部件:
事件源:谁被监听了
下面这三个家伙被监听了:ServletContext、HttpSession、ServletRequest
事件:什么事情发生会被监听
举例:
ServletContext初始化和销毁的事件:contextInitialized、contextDestroyed
HttpSession创建和销毁的事件:sessionCreated、sessionDestroyed
ServletRequest创建和销毁事件:requestInitialized、requestDestroyed
事件监听器:
当监听到事情发生时,采取的动作
自定义一个类,比如,实现HttpSessionListener接口中的sessionCreated、sessionDestroyed的方法,采取的动作需要在方法中实现自己的逻辑。
2. Filter的初始化
public void init(FilterConfig filterConfig)throws ServletException;//初始化
Filter的创建和销毁由web服务器负责。
web应用程序启动时,web服务器将创建Filter的实例对象,并调用其init方法,读取web.xml配置,完成对象的初始化功能。
Filter对象只会创建一次,init方法也只会执行一次。
执行拦截
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException;//拦截请求
Filter销毁
public void destroy();//销毁
Filter对象创建后会驻留在内存,当web应用移除或服务器停止时才被销毁。
该方法在Filter的生命周期中仅执行一次。在这个方法中,可以释放过滤器使用的资源。
这个方法完成实际的过滤操作。当客户请求访问与过滤器关联的URL的时候,Servlet过滤器将先执行doFilter方法。FilterChain参数用于访问后续过滤器。
编码过滤:统一编码。
敏感词过滤:对一些敏感的词用其他符号代替。
认证过滤:对用户请求进行统一的认证。
登录和审核过滤:对用户的访问请求进行记录和审核。
图像装换过滤:转换图像格式。
数据压缩过滤:对用户发生的数据进行压缩,从而减少传输量。
3. 拦截器(Interceptor)
拦截器的配置一般在SpringMVC的配置文件中,使用Interceptors标签,具体配置如下:
<mvc:interceptors>
<mvc:interceptor>
<mvc:mapping path="/**" />
<bean class="com.scorpios.atcrowdfunding.web.LoginInterceptor"></bean>
</mvc:interceptor>
<mvc:interceptor>
<mvc:mapping path="/**" />
<bean class="com.scorpios.atcrowdfunding.web.AuthInterceptor"></bean>
</mvc:interceptor>
</mvc:interceptors>
(2)拦截器(Interceptor):它依赖于web框架,在SpringMVC中就是依赖于SpringMVC框架。在实现上,基于Java的反射机制,属于面向切面编程(AOP)的一种运用,就是在service或者一个方法前,调用一个方法,或者在方法后,调用一个方法,比如动态代理就是拦截器的简单实现,在调用方法前打印出字符串(或者做其它业务逻辑的操作),也可以在调用方法后打印出字符串,甚至在抛出异常的时候做业务逻辑的操作。
由于拦截器是基于web框架的调用,因此可以使用Spring的依赖注入(DI)进行一些业务操作,同时一个拦截器实例在一个controller生命周期之内可以多次调用。但是缺点是只能对controller请求进行拦截,对其他的一些比如直接访问静态资源的请求则没办法进行拦截处理。
拦截器和filter对比图片