JSP九大内置对象_重定向转发_Cookie_Session

来源:互联网 发布:印象笔记怎么用 知乎 编辑:程序博客网 时间:2024/05/22 16:42

一、 JSP九大内置对象

JSP中一共预先定义了9个这样的对象,分别为:requestresponsesessionapplicationoutpagecontextconfigpageexception

 

1request对象

request对象是javax.servlet.httpServletRequest类型的对象。 该对象代表了客户端的请求信息,主要用于接受通过HTTP协议传送到服务器的数据。(包括头信息、系统信息、请求方式以及请求参数等)。request对象的作用域为一次请求

 

2response对象

response代表的是对客户端的响应,主要是将JSP容器处理过的对象传回到客户端。response对象也具有作用域,它只在JSP页面内有效。

 

3session对象

session对象是由服务器自动创建的与用户请求相关的对象。服务器为每个用户都生成一个session对象,用于保存该用户的信息,跟踪用户的操作状态。session对象内部使用Map类来保存数据,因此保存数据的格式为 “Key/value”。session对象的value可以使复杂的对象类型,而不仅仅局限于字符串类型。

 

4application对象

 application对象可将信息保存在服务器中,直到服务器关闭,否则application对象中保存的信息会在整个应用中都有效。与session对象相比,application对象生命周期更长,类似于系统的“全局变量”。

 

5out对象

out对象用于在Web浏览器内输出信息,并且管理应用服务器上的输出缓冲区。在使用out 对象输出数据时,可以对数据缓冲区进行操作,及时清除缓冲区中的残余数据,为其他的输出让出缓冲空间。待数据输出完毕后,要及时关闭输出流。

 

6pageContext对象

pageContext对象的作用是取得任何范围的参数,通过它可以获取 JSP页面的outrequestreponsesessionapplication等对象。pageContext对象的创建和初始化都是由容器来完成的,在JSP页面中可以直接使用pageContext对象。

 

7config对象

config对象的主要作用是取得服务器的配置信息。通过 pageConext对象的getServletConfig() 方法可以获取一个config对象。当一个Servlet初始化时,容器把某些信息通过 config对象传递给这个Servlet。 开发者可以在web.xml文件中为应用程序环境中的Servlet程序和JSP页面提供初始化参数。

 

8page对象

page对象代表JSP本身,只有在JSP页面内才是合法的。page隐含对象本质上包含当前Servlet接口引用的变量,类似于Java编程中的this 指针。

 

9exception对象

exception对象的作用是显示异常信息,只有在包含 isErrorPage="true"的页面中才可以被使用,在一般的JSP页面中使用该对象将无法编译JSP文件。excepation对象和Java的所有对象一样,都具有系统提供的继承结构。exception对象几乎定+-+义了所有异常情况。在Java程序中,可以使用try/catch关键字来处理异常情况; 如果在JSP页面中出现没有捕获到的异常,就会生成exception 对象,并把exception 对象传送到在page指令中设定的错误页面中,然后在错误页面中处理相应的exception 对象。

 

二、 重定向和转发

比较项

转发

重定向

调用方法

req.getRequestDispatcher("AcctMain.jsp").forward(req, resp)

resp.sendRedirect(url);

客户端发送请求次数

1

2

是否共享request,response对象

资源地址限制

只能在本应用内部

不限制

浏览器地址栏

地址不改变

地址改变

 

三、 状态管理之Cookie

1. Cookie的作用:客户端管理状态(数据)

2. 在服务器-客户端之间维护一组数据,传输时是利用HTTP头部set-Cookie进行传输

3. Cookie的使用:

Cookie c =new Cookie(“cookieName”, “cookieValue”);

response.addCookie(c);

4. 如何访问Cookie

Cookie[] cs = req.getCookies();

if (cs != null) {

for (Cookie c : cs) {

if (c.getName().equals("isLogin") && c.getValue().equals("true")) {

return;

}

}

}

修改Cookie: c.setValue(“newValue”)修改完成后需要重新addCookie

5. Cookie的生存期

可以调用c.setMaxAge来设置生存期参数分三种情况

Seconds>0:浏览器要保存Cookie的最长时间为设置的参数值,如果超过指定的时间,浏览器会删除这个Cookie。此时Cookie保存在硬盘上Seconds=0:删除Cookie.在修改Cookie的生存时间为0后,随着response发送回客户端,替换原有Cookie因生命周期到了即将该Cookie删除Seconds<0:缺省值,浏览器会将Cookie保存到内存中

6. Cookie的使用限制

1) 可以被客户端禁用,如果客户端禁用了Cookie,那么依赖与其实现的功能也将被禁用;

2) 保存与客户端,不安全;

3) 保存数据量较少,且Cookie的数量有限制;

4) 只能保存字符类型数据

7.Session

  作用:保存与服务器端,记录一次会话的状态

  实现:利用Cookie在服务器和客户端之间传送状态数据(如果客户端禁用Cookie SessionID就无法传递)

  Session的生命周期:

     从一个用户打开一个浏览器,到关闭浏览器,或者登录到登出

     Session有失效时间,可以通过配置文件、调用setMaxInactiveInterval方法设置超时时间

 8服务器

  主要API方法:

  session.isNew()//方法 判断是否是一个新的session  可以用它来统计访问量

  A.如何在Servlet中取得SessionHttpSession session=request.getSession();

  B.Session写值:session.setAttribute(paraName,paraValue);//isLogin,true

  C.Session取值:Objecto=s.getAttribute("isLogin");//isLogin是setAttribute的名字

8.客户端在禁用Cookie的情况下,如何实现SessionID的传递

      URL重写:response.encodeRedirectURL("ShowSession.jsp") 

       经过URL重写后,SessionID会作为参数添加到URL的后面

9.CookieSession的比较

  比较项         Cookie                Session

  存储位置       客户端               服务器端

  支持的数据类型  字符串              所有类型

  数据量        数据量大小有限制      保存数量大

               (一般是4kCookie

                项个数有限制

  安全性                             

  使用           不那么重要的数据     重要数据

10.典型应用

   1控制用户登录

   2图片验证码

   3统计网站/应用访问量

常见错误

1.Cannot forward after response has been committed

原因:重复forward

原创粉丝点击