JAVA Web开发技术应用-监听器

2018-05-31  本文已影响37人  Hey_Shaw

Web监听器有Servlet规范提供,可监听客户端请求与服务端操作。

062.png

application:上下文对象,由容器创建和初始化,它的范围为整个Web应用,而且整个Web应用只会有一个application存在,当Web服务器关闭时,就会把application销毁。

session:保持上下文的机制,针对每个会话,放在服务器端通过sessionId区分,在浏览器和服务器结束后都会销毁session。

request:当客户发送请求时,容器就会创建一个ServletRequest对象来封装请求数据,同时ServletResponse对象来封装响应数据。

Web监听器

Web监听器的用途

监听器的启动顺序,取决于我们在web.xml的注册顺序

优先级:

A(监听器) --> B(过滤器) --> C(Servlet)

按监听器对象划分

1、用于监听应用程序环境对象(ServletContext)的事件监听器

2、用于监听用户会话对象(HttpSession)的事件监听器

3、用于监听请求消息对象(ServletRequest)的事件监听器

按监听的事件划分

1、监听域对象自身的创建和销毁的事件监听器

web.xml配置
<context-param>
    <param-name>initParam</param-name>
  <param-value>imooc</param-value>
</context-param>

在contextInitialized方法体内通过 sce.getServletContext().getInitParameter("initParam")获取

2、监听域对象中的属性的增加和删除的事件监听器

3、监听绑定到HttpSession域中的某个对象的状态的事件监听器

按监听的事件划分

监听绑定到HttpSession域中的某个对象的状态的事件监听器

HttpSession中的对象状态

绑定 ---> 解除绑定 钝化 ---> 活化

session钝化机制:session正常是放到服务器内存当中,服务器会对每个在线用户创建一个session对象。当在线用户很多时,session内存的开销将是巨大的,会直接影响web服务器的性能,session钝化机制就可以解决这个问题。session钝化机制的本质就是把服务器不经常使用的session对象暂时序列化到系统文件或者数据库系统当中,整个过程由服务器自动创建。

Tomcat中两种Session钝化管理器

org.apache.catalina.session.StandardManger

Servlet规范

钝化与活化必须实现Serializable

org.apache.catalina.session.Persistentmanager

servlet3.0下监听器的用法

@WebListener:该注解用于将类声明为监听器,被@WebListener标注的类必须实现以下至少一个接口:
@WebListener的常用属性
<listener>
    <listener-class>footmark.servlet.SimpleListener</listener-class>
</listener>

@WebListener("This is only a demo listener")
public class SimpleListener implements ServletContextListener{......}
上一篇 下一篇

猜你喜欢

热点阅读