Servlet中Request, ServletContext,Session域和Jsp中Page域的区别

Request域: 
Servlet中采用请求-响应模式,一个Request则保存该请求的所有信息;其作用范围为该个Request对象中,其主要作用携带Cookie和转发功能:

① 携带Cookie

Cookie用于保存服务器给客户发出的相关信息并将其保存在浏览器端,作用:保存Session的标识符等,应用场景:自动登录,显示上次访问时间等。创建一个Cookie对象并通过Response的addCookie方法写到request域中。

② 转发功能:

Request.getRequestDispatcher(url).forward(req,rep)方式将请求转发给另一页面,客户端只发出一次请求,由服务器将该请求转发,所以仍是一次请求。与ServletContext对象的转发功能不同的是ServletContext.getRequestDispatcher(url).forward(req,rep)方法在携带数据转发时会有线程安全问题,所以携带数据转发使用request对象的功能。



ServletContext域: 
作用范围:整个webApps内的一个应用程序范围。也就是说Request域只能由相应的Requset访问(别的request不能访问),而ServletContext可以由该应用程序下的所有Servlet和Request访问,所以它的作用是实现数据的共享。共享的数据一般为该应用程序共同使用的数据,例如数据库的url,密码,用户名等等。

① 实现数据共享:

第一种方式:使用ServletContext对象的set/getAttribute方法,ServletContext对象通过ServletConfig对象或this.getServletContext()获取。

第二种方式是在web.xml中配置:

<context-param>
<param-name>password</param-name>
<param-value>123456</param-value>
</context-param>
② 转发功能:

ServletContext.getRequestDispatcher(url).forward(req,rep)方法转发,携带数据时有线程安全问题:由于SerletContext的作用范围,当一个请求访问该Servlet时,携带的数据存在ServletContext中,在该请求还未转发时,另一个请求就改变了ServletContext中的数据的值,导致最后的数据不符。而数据存在request中就不会被另一请求访问并篡改,从而没有线程安全问题。



Session域:

Session即一个会话:指的是客户打开一个浏览器,发出各种请求,一直到最后关闭该窗口的整个过程。作用:用来保存数据,数据是保存在服务器端(与Cookie的区别),一般用于数据的验证。服务器会为打开每个浏览器创建一个Session对象,该Session对象内的数据可以由在相应的会话中客户发出的任意请求访问到。所以其作用范围为该会话过程内,直到Session摧毁。

① Session的生命周期:

产生:第一次访问到getSession()代码时创建,getSession()方法表示若该会话没有Session就实例化一个Session,若有则直接使用。 
摧毁

  1. 自动摧毁:通过设置Session的生命周期来规定其摧毁时间。(以秒为单位) 
    第一种方式:Session对象的set/getMaxInactiveInterval()方法设置,setMaxInactiveInterval(-1)表示session对象永不超时,不会被摧毁。 
    第二种方式:在web.xml中配置
<session-config>
<session-timeout>30*24*60*60</session-timeout>
</session-config>

2.手动摧毁:session.invalidate()

② Session底层原理
  1. 服务器为每个浏览器创建一个Session,在进行数据交互时;服务器如何实现一个Session为一个用户浏览器服务? 
    原理:为创建的每个Session分配一个SessionId,并以Cookie的形式写给客户浏览器,当用户浏览器下次访问时,服务器会寻找SessionId,找到则分配对应的Session,若没有则创建Session。

  2. Cookie被关闭怎么办? 
    有时候客户浏览器关闭了Cookie,这时SessionId就不能通过Cookie写给客户浏览器,就需要用到URL-Rewriting重写URL,即将SessionId写到URL地址中写给用户。



Jsp中的Page域: 
作用范围:整个Jsp页面。 

Page域指的是PageContext对象,该对象保存了Jsp的其它八大隐式对象的引用: 

get/setRequest|Response|Config|Session|Application|Page|Exception。



总结: 
Request域:只返回给客户信息,无需校验,一个Request占有一个Request域,其它Request不可以访问。 
Session域:用于校验信息,一次会话含有多个Request, 在一个会话中多个Request占有一个Session域,相互之间可以访问。 
ServletContext:用于一个应用程序中的Sevlet之间的请求交互。 
Page域:Jsp页面。

范围大小比较:Page域<Request域<Session域<ServletContext域

猜你喜欢

转载自blog.csdn.net/yang5726685/article/details/81006207