JAVA中的四大域对象总结

  • 域对象的定义

可以在不同的Servlet中进行数据传递的对象就称为域对象。

  • 域对象必须有的方法
    setAttribute(name,value);存储数据的方法
    getAttribute(name);根据name获取对应数据值
    removeAttribute(name);删除数据
  • 四种域对象及其使用范围
  1. page(jsp有效)–>page域指的是pageContext.(前后端分离模式下基本不用了,本文也就不讲了)
  2. request(一次请求)–>request域指的是HttpServletContext(需要掌握)
  3. session(一次会话)–>session域指的是HttpSession
  4. application(当前web应用)–>application域指的是application ServletContext;
    之所以他们是域对象,原因是他们都内置了map集合,都有setAttribute和getAttribute方法。

Request域

  • Request域对象的数据传递

request对象提供了一个getRequestDispatcher方法,该方法返回一个RequestDispatcher对象,调用这个对象的forward方法可以实现请求转发,从而共享请求中的数据。

  • Request的生命周期
  1. 当请求来时创建request对象
  2. 当请求结束时,request就销毁。
  3. 每次请求都是一个新的request对象。
    request域对象,是建议使用,并被频繁使用的域对象,因为它声明周期比较短,也就代表着,它效率比较高,释放资源比较及时。

Session域对象

  • Session生命周期

在第一次调用request.getSession()方法时,服务器会检查是否已经有对应的session,如果没有就在内存中创建一个session并返回。
(1)当一段时间内session没有被使用(默认为30分钟),则服务器会销毁该session。
(2)如果服务器非正常关闭,没有到期的session也会跟着销毁。
(3)如果调用session提供的invalidate(),可以立即销毁session。
用户打开浏览器访问,创建session(开始),session超时或者被声明失效,该对象生命周期结束;

  • Session的作用范围

HttpSession 在服务器中,为浏览器创建独一无二的内存空间,在其中保存会话相关的信息
注意:服务器正常关闭,再启动,Session对象会进行钝化和活化操作。同时如果服务器钝化的时间在session 默认销毁时间之内, 则活化后session还是存在的。否则Session不存在。 如果JavaBean 数据在session钝化时,没有实现Serializable 则当Session活化时,会消失。

  • 在同一服务器上不同的request请求是会得到唯一的session

Session生成时机:request对象调用getSession方法时生成,服务器会为该Session对象生成一个唯一的ID。
服务器端响应客户端请求时会在报文头中设置Set-Cookie属性,该属性内容中有一个JSESSIONID即是Session对象的标识,返回后由浏览器进行处理。客户端再次发送请求时,浏览器会在报文头中自动追加Cookie属性,该属性将JSESSIONID传到服务器端。在服务器端用request.getSession时会取得SessionId对应的对象而不会重新生成Session。

  • 监听Session的利器HttpSessionListener

Session创建事件发生在每次一个新的session创建的时候,类似地Session失效事件发生在每次一个Session失效的时候。任何一个Session被创建或者销毁时,都会通知SessionCounter 这个类。比如在统计网站在线人数的这个场景下,可以使用HttpSessionListenner进行监听。

  • Session何时创建

Session并不是一打开网页就创建了session对象。对于Servlet的请求中,只有当Servlet内部调用了如下代码,才会生成session

HttpSession session = request.getSession();
// or
HttpSession session = request.getSession(true);

如果写成如下,则不会创建session

HttpSession session = request.getSession(false);

加入我们访问的是jsp页面,因为Jsp页面内置了session对象,封装了调用session的代码,则一打开jsp页面会创建session

ServletContext域对象

  • ServletContext的生命周期

随着WEB应用的创建而创建,随着WEB应用关闭而销毁。

  • 作用范围

整个WEB应用

  • 作用

1.不同的servlet之间进行调整。

this.getServletContext().getRequestDispatcher("/servlet1").forward(request,response); 
  • 读取文件
  1. Web应用的根目录
InputStream stream = this.getServletContext().getResourceAsStream("conf.properties");
Properties properties = new Properties();
properties.load(stream);
String name = properties.getProperty("name");
String password = properties.getProperty("password");
  1. Src下面
InputStream stream = MyServlet.class.getClassLoader().getResourceAsStream("conf.properties")
  1. Src下某个包下面,则
InputStream stream = MyServlet.class.getClassLoader().getResourceAsStream("com/haoeasy/conf.properties")

4.获取绝对路径

MyServlet.class.getClassLoader().getResourceAsStream("com/haoeasy/conf.properties").getPath()
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值