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

一、 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取值:Object o=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

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值