jsp 九大隐性对象讲解

来源:互联网 发布:淘宝购买商品快递丢件 编辑:程序博客网 时间:2024/05/10 22:03
四大域对象详解    
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就可以操作其他三个作用域中的变量。



0 0
原创粉丝点击