v 过滤器
Ø 可以解释请求和发送的客户端之前的应答信息。
ª 过滤器对请求和应答的首部和主体有完全的访问权限。
ª 过滤器实现访问控制,可以将应用程序配置为需要受保护的所有资源的URL请求 都通过访问控制过滤。
例:
<filter>
<filter-name>accessControl</filter-name>
<filter-class>
Com.ora.jsp.servlets.AccessControlFilter
</filter-class>
<init-param>
<param-name>loginPage</param-name>
<param-value>login.jsp</param-value>
</init-param>
<filter-mapping>
<filter-name>accessControl</filter-name>
<url-pattern>/protedted/*</url-pattern>
</filter-mapping>
</filter>
ª <init-param>元素定义了过滤器的初始化参数
ª <filter-mapping>告诉容器所有与模式向匹配的请求都应该允许通过访问控制过滤器。
ª filter类中的调用:chain.doFilter
处理过滤器的其余部分(如果有的话),最终处理请求的servlet或JSP页面。
ª 过滤器类必须实现javax.servlet.Filter接口
ª 当容器收到与过滤器的影射相匹配的请求时,会调用doFilter()方法
ª doFilter()方法中的FilterChain接口实例,包含了对所有模式影射与请求相匹配的过滤
器的有序列表的引用,并在链中没有更多的过滤器时,使用doFilter方法调用链中
的下一个过滤器或目标资源(servlet或JSP页面)。
v监听器
Ø 允许应用程序对特定的事件做出应答。
ª 容器会注册监听器,然后容器会在适当的时间调用这些事件方法。
Ø主要的监听器接口
ª HttpSessionListener
ª ServletContextAttributeListener
ª ServletContextListener
当应用程序启动时,会在发送任何请求之前调用contextinitialized()方法
getInitParameter()方法,返回在配置描述符中定义的环境初始化参数的值。
ª HttpSessionActivation-Listener
ª HttpSessionAttribute-Listener
具体介绍可以参阅read-AppFuse相关主题。
Ø 在组件类型之间共享数据
ª 不同的组件servlet、JSP、监听器和过滤器等,通过HttpServletRequest、HttpSession
和ServletContext达到数据共享
ª 这些类都提供了得一组方法,可以使用这些方法来设置、获取和删除属性。
Public void setAttribute( String name,Object value)
Public Object getAtttibute(String name)
Public void removeAttribute(String name)
例:在应用程序作用域共享counter变量
ª 在监听器共享
ServletContext application = (ServletContextEvent)sce.getServletContext()
Counter = application.getAttribute(COUNTER_ATTR);
ª 在servlet共享
ServletContext context = config.getServletContext();
Counter = context.getAttribute(“COUNTER_ATTR”);
会话域共享
HttpSession session = request.getSession();
ª 在JSP共享
Application.getAttribute(“COUNTER_ATTR”);
例:
<listener>
<listener-class>
Com.ora.jsp.servlets.ResourceManagerListener
</listener-class>
</listener>