(1)直接在web contain中进行对象的实例化。html
内置对象java |
类型web |
做用域数据库 |
pageContext浏览器 |
javax.servlet.jsp.pageContexttomcat |
page安全 |
request服务器 |
javax.servlet.http.HttpServletRequestcookie |
requestsession |
response |
javax.servlet.http.HttpServletResponse |
page |
session |
javax.servlet.http.HttpSession |
session |
application |
javax.servlet.ServletContext |
application |
config |
javax.servlet.ServletConfig |
page |
out |
Java.servlet.jsp.JspWriter |
page |
page |
java.lang.Object |
page |
exception |
java.lang.Throwable |
page |
(2)jsp内置对象分类
与servlet有关的隐含对象:page,config
与input/output有关的隐含对象:out,request,response
与jsp执行时有关的context的隐含对象:session,application,pageContext
与error有关的隐含对象:exception
(3)属性的设置和取得
设置属性:public void setAttribute(String name,Object.value)
取得属性:public void getAttribute(String name)
(4)四种属性保存范围
在一个页面范围内:page
在一次服务器请求范围内:request
在一次会话范围内:session
在一个应用服务器范围内:application
(5)page范围
Page范围经过PageContext对象来设置,将属性保存在一次请求范围以内,必须使用服务器端跳转<jsp:forward/>
(6)session范围
只保留一个用户的信息
(7)application范围
全部的用户均可以取得此信息,此信息在整个服务器上被保留。Application属性范围值,只要设置一次,则全部的网页窗口均可以取得数据。
Application,session,request都须要跨多个页,属性保存时内存开销大。若是能使用request就不适用session,能使用session的就不要使用application。
(8)pageContext默认状况下表示一个页面的保存范围
public void setAttribute(String name,Object value,int scope) public static final int APPLICATION_SCOPE:application范围 public static final int SESSION_SCOPE:session范围 public static final int REQUEST_SCOPE:request范围 public static final int PAGE_SCOPE:page范围
四种属性范围都是依靠pageContext展开的,可是在开发中,每每使用session,request范围
session对象
(1)session功能
Session对象主要用于保存用户的各类信息,直到它的生命周期超过或被人为释放掉为止,能够经过session对象来判断此用户是不是合法用户。
Session对象是javax.Servlet.http.HttpSession接口的实例化对象,session属于http协议范畴以内的对象,因此只有惟一http包下有此接口,没有任何继承关系,用户只要一链接到服务器,则马上分配一个session给用户。
(2)主要方法
session.getID():服务器上经过session来分别不一样的用户,sessionID:任何连接到服务器上的用户,服务器都会为之分配惟一的一个不会重复的sessionID。由服务器统一管理,人为不能控制。
session.getId().length():id的长度为32位
session.isNew():判断是不是新的用户
session.invalidate():使session失效
session.getCreationTime():获得session的建立时间,返回long类型,经过Date获得时间
session.getLastAccessedTime():获得最后一次操做时间,返回long类型
实例:
<%@page contentType="text/html;charset=gb2312"%> <%@page import="java.util.*"%> <% long l = session.getCreationTime() ; long l2 = session.getLastAccessedTime() ; %> <h1>session CREATE : <%=new Date(l)%></h1> <h1>session last access: <%=new Date(l2)%></h1> <h1><%=(l2-l)/1000%></h1>
假如须要求出用户在线时间,使用如下公式:最后操做时间—建立的时间
(3)session属性的设置
session.setAttribute(String name,Object value)
session.getAttribute(String name)
session.removeAttribute(String name)
(4)两种写法的区别
if(name.equals("mldn")&&pass.equals("password")):假如其中的name和pass没有被初始化,那么在执行此句子的时候会出现nullpointexception。
if("mldn".equals(name)&&"password".equals(pass)):若是使用该写法则不会出现错误。
(5)session用法:验证用户是否登录。
(6)session与cookie
Session和cookie用于跨网页共享数据。Session记录独有的我的信息,在不一样页面中传递,使用setAttribute,getAttribute方法;Cookie保存于客户端,供浏览器与web服务器互通数据用的纯文字文件,当ie执行的时候会在计算机中产生一个cookie。Session比cookie更安全,session比cookie更占用资源,session使用了cookie的机制,若是cookie被禁用,则session也没法使用。
application与config对象
(1)application简介
Application对象主要的做用就是保存公共信息,属于javax。Servlet。ServletContext,此工做目录的路径不是固定的,有可能此工做目录在c盘上或是在d盘获得的工做目录的真实路径。Application是在整个服务器中保持的只有一个实例的对象。
(2)属性操做: setAttribute(),getAttribute(),removeAttribute()
(3)真实路径: application.getRealPath(String path),其中String path是"/"。在实际使用中用getServletContext()方法代替application。格式以下:
getServletContext().getRealPath("/")
this.getServletContext.getRealPath("/")
(4)Jsp安全性Config对象
(a) 在j2ee中安全性体如今工做目录的WEB-INF文件夹,页面保存在此文件夹下,外面没法发现此文件夹内的文件,若是要使此文件夹内的文件能被用户访问,则修改WEB-INF文件夹下存在的web.xml文件,web.xml文件属于整个web站点的配置文件。
<……mapping start> <servlet> <servlet-name></servlet-name> <jsp-file></jsp-file> <init-param> <param-name></param-name> <param-value></param-value> </init-param> </servlet> <servlet-mapping> <servlet-name></servlet-name> <url-pattern>/浏览器中输入的地址</url-pattern> </servlet-mapping> <……mapping end>
修改web.xml以后重启服务器。
(b)config对象
Config对象通常用来取得服务器的初始化配置参数,若要使用此对象应在WEB-INF/web.xml之中配置。Config对象在javax.Servlet.servletConfig中取得初始化参数的方法:
public string getInitParameter(String name)
经过此种功能,能够将数据库连接的一些信息写在配置文件之中,下面两种方法相似,是取得所有配置参数的:
public Enumeration getInitParameterNames()
request.getParameterNames()
另外附上一篇文章:
1.简单说 page指当前页面。在一个jsp页面里有效
2.request 指从http请求到服务器处理结束,返回响应的整个过程。在这个过程当中使用forward方式跳转多个jsp。在这些页面里你均可以使用这个变量。
3.Session 有效范围当前会话,从浏览器打开到浏览器关闭这个过程。
4.application它的有效范围是整个应用。
做用域里的变量,它们的存活时间是最长的,若是不进行手工删除,它们就一直可使用
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都是彻底隔离的,不管如何修改都不会影响其余人的数据。
问题:page、request、session、application的做用范围?
书中解答,此处只摘录重要语句:
page:用户请求的当前页面;
Request:用户请求访问的当前组件,以及和当前web组件共享同一用户请求的web组件。如:被请求的jsp页面和该页面用<include>指令包含的页面以及<forward>标记包含的其它jsp页面;
Session:同一个http会话中的web组件共享它;
Application:整个web应用的所用web组件共享它。
此处我举个例子说明
一个网站MyWebSite,其包含7个jsp页面,分别为master.jsp、top.jsp、main.jsp、foot.jsp、login.jsp、success.jsp和news.jsp。master.jsp页面经过<include>指令包含top.jsp、main.jsp、foot.jsp三个页面,当用户经过login.jsp登陆成功后,进入success.jsp页面而后经过此页面的<forward>标签跳转到master.jsp页面中。
咱们在success.jsp页面中加入以下代码(此处用到jstl标签)
<c:set value="aaa" var="test1" scope=”page” /> <c:set value="aaa" var="test2" scope=”request” /> <c:set value="aaa" var="test3" scope=”session” /> <c:set value="aaa" var="test4" scope=”application” />
<jsp:forward page=”master.jsp”/ >这里一一说明
1.变量 test1 只在success.jsp内有效;
2.变量 test2 在success.jsp、master.jsp、top.jsp、main.jsp、foot.jsp中有效;
3.变量 test3 在7个页面中都有效(包括login.jsp和news.jsp);
4.变量 test4 在整个网站,当前也就是7个页面中都有效(包括login.jsp和news.jsp)。
Test3和test4有效范围同样,有什么区别呢?
其实区别蛮大的,我只说明一点,假如此时又有另外一个用户访问master.jsp页面,那么test3相对于这个用户来讲就无效,而test4倒是有效的。或者当第一个登陆的用户关闭浏览器后,再从新访问master.jsp时,test3就无效,而test4却有效。