七、jsp基础(三)- 域对象

一、 什么是域对象?


	保存数据和获取数据,用于在不同资源之间实现共享数据

	域对象必须有的方法:
					  setAttribute(name,value);存储数据的方法
    				  getAttribute(name);根据name获取对应数据值
    				  removeAttribute(name);删除数据

二、 域对象


	## ServletContext 		context域
	## HttpServletRequet    request域
	## HttpSession          session域     --Servlet学习的
	## PageContext          page域	       --jsp学习的


	servlet中有三个域对象:
				ServletContext、HttpServletRequet 、HttpSession         

	jsp中有四个域对象:
				ServletContext、HttpServletRequet 、HttpSession 、PageContext          

域对象作用范围:


	page域: 只能在当前jsp页面中使用(当前页面)
	request域: 只能在同一个请求中使用(转发)
	session域: 只能在同一个会话(session对象)中使用(私有的)
    context域: 只能在同一个web应用中使用。(全局的)
	
	之所以他们是域对象,原因是他们都内置了map集合,都有setAttribute和getAttribute方法。

2.1 Request域对象

Request域对象的数据传递

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

Request的生命周期

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

2.2 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

2.3 ServletContext域对象

ServletContext的生命周期

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

作用范围

整个WEB应用

作用

1.不同的servlet之间跳转


			this.getServletContext().getRequestDispatcher("/servlet1").forward(request,response); 

2.读取文件

a.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");

b.Src下面
InputStream stream = MyServlet.class.getClassLoader().getResourceAsStream("conf.properties")
c.Src下某个包下面
InputStream stream = MyServlet.class.getClassLoader().getResourceAsStream("com/haoeasy/conf.properties")
发布了94 篇原创文章 · 获赞 0 · 访问量 654

猜你喜欢

转载自blog.csdn.net/weixin_45602227/article/details/103938557