jsp 九大隐性对象讲解

四大域对象详解    
JSP中隐式对象的名称    范围名称     具体的类型   
pageContext       page         javax.servlet.jsp.PageContext   
request         request     javax.servlet.ServletRequest  (显示完数据就没有用了)   
session         session       javax.servlet.http.HttpSession   (显示完数据了,过一会自己 还要用)  

application       application      javax.servlet.ServletContext   (显示完数据了,大家都要用。不建议使用,如果使用,必须同步处理)


JSP九大内置对象  
JSP的内置对象引用名称     对应的类型     
request       HttpServletRequest  
response      HttpServletResponse   
session          HttpSession(有开关的:page指令的session属性的取值)  
application     ServletContext  
config      ServletConfig  
page        this(当前Servlet对象)   
exception       java.lang.Throwable(有开关的:page指令的isErrorPage属性改为true)     
out        JspWriter   pageContext      javax.servlet.jsp.PageContext非常重要     
pageContext有三大作用:   
1、本身是一个域对象。同时还能操作其他三个域对象(PageContext ServletRequest    HttpSession   ServletContext)  本身表示的域范围 是本页面。          
void setAttribute(String name,Object value) 

 void removeAttribute(String name)              
       Object getAttribute(String name)   操作其他的三个域对象      
       void setAttribute(Stringname,Objectvalue,intscope)       
       void removeAttribute(String name,inscope)       
       Object getAttribute(String name,int scope)                参数int scope是由PageContext类提供的静态变量规定的。       
       PageContext.PAGE_SCOPE:页面范围(是PageContext本身中的那个Map,代号page):仅在本页 中可用     
        PageContext.REQUEST_SCOPE:请求范围(是ServletRequest中的那个Map,代号request):当有 request请求时      
        PageContext.SESSION_SCOPE:请求范围(是HttpSession中的那个Map,代号session):用的很多, 会话期间    

PageContext.APPLICATION_SCOPE:请求范围(是ServletContext中的那个Map,代号application): 用的不多,全局可用,也就是该应用都可用,注意:使用时,应该加上同步处理,而且同步应该包括少部分的代码,效率低。   (非常有用)Object findAttribute(String name):

        依次按照page request session application范围搜索指定名称的 对象,找到为止  。     
        2、获取其他8个隐式对象  getxxx  3、提供了转发和包含的方便方法   RequestDispatcher rd = request.getRequestDispatcher("/url");       
        rd.forward(request,response);       pageContext.forward("url");        pageContext.include("url"); 



内置对象(又叫隐含对象,有9个内置对象):不需要预先声明就可以在脚本代码和表达式中随意使用

1-out:

 javax.servlet.jsp.JspWriter类型,代表输出流的对象。作用域为page(页面执行期)

request:javax.servlet.ServletRequest的子类型,此对象封装了由WEB浏览器或其它客户端生成地HTTP

请求的细节(参数,属性,头标和数据)。作用域为request(用户请求期)。
方法由可查看API

response:javax.servlet.ServletResponse的子类型,此对象封装了返回到HTTP客户端的输出,向页面

作者提供设置响应头标和状态码的方式。经常用来设置HTTP标题,添加cookie,设置响应内容的类型和状

态,发送HTTP重定向和编码URL。作用域为page(页面执行期)。


pageContext:javax.servlet.jsp.PageContext(抽象类)类型,作用域为page(页面执行期)。此对象

提供所有四个作用域层次的属性查询和修改能力,它也提供了转发请求到其它资源和包含其他资源的方法


该对象的方法都是抽象方法

session:javax.servlet.http.HttpSession类型,主要用于跟踪对话。作用域session(会话期—)。

HttpSession是一个类似哈希表的与单一WEB浏览器会话相关的对象,它存在于HTTP请求之间,可以存储任

何类型的命名对象。
如果不需要在请求之间跟踪会话对象,可以通过在page指令中指定session="false"
需要记住的是pageContext对象也可以与session.getAttribute(),session.setAttribute()一样的方式取

得并设置会话属性。

application:javax.servlet.ServletContext类型,servlet的环境通过调用getServletConfig

().getContext()方法获得。作用域是application(整个程序运行期)。它提供了关于服务器版本,应用

级初始化参数和应用内资源绝对路径,注册信息的方式


config:javax.servlet.ServletConfig,作用域为page(页面执行期)

exception:java.lang.Throwable,通过JSP错误页面中一个catch块已经益出但没有捕获的

java.lang.Throwable的任意实例,传向了errorPage的URI。作用域为page(页面执行期)。注意

exception只有在page指令中具有属性isErrorPage="true"时才有效。

page:java.lang.Object类型,指向页面自身的方式。作用域为page(页面执行期



概要
HTTP是无状态(stateless)协议;
Web Server 对每一个客户端请求都没有历史记忆;
Session用来保存客户端状态信息;
由Web Server 写入;
存于服务器端,其本质远离通过回送一个cookie对象(含用户基本数据)给浏览器;
客户端的每次访问都把上次的session记录就会调用相应的cookie对象传递给Web Server;
Web Server读取客户端提交的session来获取客户端的状态信息

application 对象负责提供应用程序在服务器中运行时的一些全局信息,常用的方法有getMimeType和getRealPath等。

out 对象代表了向客户端发送数据的对象,与“response” 对象不同,通过“out” 对象发送的内容将是浏览器需要显示的内容,是文本一级的,可以通过“out” 对象直接向客户端写一个由程序动态生成HTML文件。常用的方法除了pirnt和println之外,还包括clear、clearBuffer、flush、getBufferSize和getRemaining,这是因为“out” 对象内部包含了一个缓冲区,所以需要一些对缓冲区进行操作的方法

“config” 对象提供一些配置信息,常用的方法有getInitParameter和getInitParameterNames,以获得Servlet初始化时的参数。

“page” 对象代表了正在运行的由JSP文件产生的类对象,不建议一般读者使用。

“exception” 对象则代表了JSP文件运行时所产生的例外对象,此对象不能在一般JSP文件中直接使用,而只能在使用了“<%@ page isErrorPage="true "%>”的JSP文件中使用


 


四个作用域:

何为作用域 
先让我们看看效果:


大概流程是这样的,我们访问04-01/index.jsp的时候,分别对pageContext, request, session,

application四个作用域中的变量进行累加。(当然先判断这个变量是不是存在,如果变量不存在,则要

把变量初始化成1。)计算完成后就从index.jsp执行forward跳转到test.jsp。在test.jsp里再进行一次

累加,然后显示出这四个整数来。

从显示的结果来看,我们可以直观的得出结论:

page里的变量没法从index.jsp传递到test.jsp。只要页面跳转了,它们就不见了。

request里的变量可以跨越forward前后的两页。但是只要刷新页面,它们就重新计算了。

session和application里的变量一直在累加,开始还看不出区别,只要关闭浏览器,再次重启浏览器访问

这页,session里的变量就重新计算了。

application里的变量一直在累加,除非你重启tomcat,否则它会一直变大。

而作用域规定的是变量的有效期限。

如果把变量放到pageContext里,就说明它的作用域是page,它的有效范围只在当前jsp页面里。

从把变量放到pageContext开始,到jsp页面结束,你都可以使用这个变量。

如果把变量放到request里,就说明它的作用域是request,它的有效范围是当前请求周期。

所谓请求周期,就是指从http请求发起,到服务器处理结束,返回响应的整个过程。在这个过程中可能使

用forward的方式跳转了多个jsp页面,在这些页面里你都可以使用这个变量。

如果把变量放到session里,就说明它的作用域是session,它的有效范围是当前会话。

所谓当前会话,就是指从用户打开浏览器开始,到用户关闭浏览器这中间的过程。这个过程可能包含多个

请求响应。也就是说,只要用户不关浏览器,服务器就有办法知道这些请求是一个人发起的,整个过程被

称为一个会话(session),而放到会话中的变量,就可以在当前会话的所有请求里使用。

如果把变量放到application里,就说明它的作用域是application,它的有效范围是整个应用。

整个应用是指从应用启动,到应用结束。我们没有说“从服务器启动,到服务器关闭”,是因为一个服务

器可能部署多个应用,当然你关闭了服务器,就会把上面所有的应用都关闭了。

application作用域里的变量,它们的存活时间是最长的,如果不进行手工删除,它们就一直可以使用。

与上述三个不同的是,application里的变量可以被所有用户共用。如果用户甲的操作修改了application

中的变量,用户乙访问时得到的是修改后的值。这在其他scope中都是不会发生的,page, request,

session都是完全隔离的,无论如何修改都不会影响其他人的数据。

我们使用public Object getAttribute(String name)获得变量值,使用public void setAttribute

(String name, Object value)将变量值保存到对应作用域中。举个pageContext的例子就是:

// page
Integer countPage = (Integer) pageContext.getAttribute("countPage");
if (countPage == null) {
    pageContext.setAttribute("countPage", 1);
} else {
    pageContext.setAttribute("countPage", countPage + 1);
}
这里先从pageContext中取出名为countPage的整数,因为返回的都是java.lang.Object类型,所以需要强

制转换成我们需要的整形。这里取得的变量如果不存在就会返回null,通过判断countPage == null来辨

别变量是否存在,如果不存在就设置为1,如果存在就进行累加,最后使用setAttribute()方法将修改后

的变量值放入pageContext。

将其中的pageContext换成request, session, application就可以操作其他三个作用域中的变量。



發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章