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中配置:

② 转发功能:

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

Session域:

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

① Session的生命周期:

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

摧毁

自动摧毁:通过设置Session的生命周期来规定其摧毁时间。(以秒为单位) 

第一种方式:Session对象的set/getMaxInactiveInterval()方法设置,setMaxInactiveInterval(-1)表示session对象永不超时,不会被摧毁。 

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

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

② Session底层原理

服务器为每个浏览器创建一个Session,在进行数据交互时;服务器如何实现一个Session为一个用户浏览器服务? 

原理:为创建的每个Session分配一个SessionId,并以Cookie的形式写给客户浏览器,当用户浏览器下次访问时,服务器会寻找SessionId,找到则分配对应的Session,若没有则创建Session。

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域

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 从三月份找实习到现在,面了一些公司,挂了不少,但最终还是拿到小米、百度、阿里、京东、新浪、CVTE、乐视家的研发岗...
    时芥蓝阅读 42,366评论 11 349
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,908评论 18 139
  • 一、cookie机制和session机制的区别**********************************...
    __Lex阅读 1,721评论 0 13
  • 一、 看来是没望了 踩在路上,看着弯月 想起了童年里的月亮 他应该是在笑 是嘲笑呢 还是被我逗笑了 人生若只如初见...
    吹吧呃呃呃阅读 436评论 7 13
  • 昨日在朋友圈读了一篇文章,朋友在感慨青春的流逝,华发早生,父母年迈,竟让我无端地生出几许彷徨和慌张。然谁又曾躲过青...
    小野猫未晞阅读 893评论 7 7