一、 JSP九大内置对象
JSP中一共预先定义了9个这样的对象,分别为:request、response、session、application、out、pagecontext、config、page、exception
1、request对象
request对象是 javax.servlet.httpServletRequest类型的对象。 该对象代表了客户端的请求信息,主要用于接受通过HTTP协议传送到服务器的数据。(包括头信息、系统信息、请求方式以及请求参数等)。request对象的作用域为一次请求。
2、response对象
response 代表的是对客户端的响应,主要是将JSP容器处理过的对象传回到客户端。response对象也具有作用域,它只在JSP页面内有效。
3、session对象
session 对象是由服务器自动创建的与用户请求相关的对象。服务器为每个用户都生成一个session对象,用于保存该用户的信息,跟踪用户的操作状态。session对象内部使用Map类来保存数据,因此保存数据的格式为 “Key/value”。 session对象的value可以使复杂的对象类型,而不仅仅局限于字符串类型。
4、application对象
application对象可将信息保存在服务器中,直到服务器关闭,否则application对象中保存的信息会在整个应用中都有效。与session对象相比,application对象生命周期更长,类似于系统的“全局变量”。
5、out 对象
out 对象用于在Web浏览器内输出信息,并且管理应用服务器上的输出缓冲区。在使用 out 对象输出数据时,可以对数据缓冲区进行操作,及时清除缓冲区中的残余数据,为其他的输出让出缓冲空间。待数据输出完毕后,要及时关闭输出流。
6、pageContext对象
pageContext 对象的作用是取得任何范围的参数,通过它可以获取 JSP页面的out、request、reponse、session、application 等对象。pageContext对象的创建和初始化都是由容器来完成的,在JSP页面中可以直接使用 pageContext对象。
7、config 对象
config 对象的主要作用是取得服务器的配置信息。通过 pageConext对象的 getServletConfig() 方法可以获取一个config对象。当一个Servlet 初始化时,容器把某些信息通过 config对象传递给这个 Servlet。 开发者可以在web.xml 文件中为应用程序环境中的Servlet程序和JSP页面提供初始化参数。
8、page 对象
page 对象代表JSP本身,只有在JSP页面内才是合法的。 page隐含对象本质上包含当前 Servlet接口引用的变量,类似于Java编程中的 this 指针。
9、exception 对象
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中取得Session:HttpSession 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.Cookie和Session的比较
比较项 Cookie Session
存储位置 客户端 服务器端
支持的数据类型 字符串 所有类型
数据量 数据量大小有限制 保存数量大
(一般是4k)Cookie
项个数有限制
安全性 差 好
使用 不那么重要的数据 重要数据
10.典型应用
1控制用户登录
2图片验证码
3 统计网站/应用访问量
常见错误
1.Cannot forward after response has been committed
原因:重复forward