JSP九大内置对象_重定向转发_Cookie_Session
来源:互联网 发布:印象笔记怎么用 知乎 编辑:程序博客网 时间:2024/05/22 16:42
一、 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取值:Objecto=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
- JSP九大内置对象_重定向转发_Cookie_Session
- JSP九大内置对象及请求转发和重定向
- JSP(二)--九大内置对象/4大范围对比/验证码/重定向
- jsp内置对象之请求转发和请求重定向
- 第五天(JSP内置对象转发和重定向)
- JSP内置对象和请求转发及重定向
- JSP内置对象request,response,重定向与转发
- Jsp知识点:九大对象,四大作用域,七大动作指令,三大编译指令,转发与重定向等
- JSP内置对象:request对象,response对象、请求重定向、请求转发
- JSP九大内置对象
- JSP内置九大对象
- JSP九大内置对象
- JSP九大内置对象
- jsp 九大内置对象
- JSP九大内置对象
- JSP九大内置对象
- JSP九大内置对象
- Jsp九大内置对象
- warning C4819: 该文件包含不能在当前代码页(936)中表示的字符,请将该文件保存为 Unicode 格式以防止数据丢失
- python学习之——通配符%s
- Java解析xml格式数据
- TCP三次握手建立连接
- 龙珠直播前50信息爬取并保存图片和天池排名爬取
- JSP九大内置对象_重定向转发_Cookie_Session
- EtherCAT 应用层协议的部分理解(一)
- c# 流
- TCP四次挥手释放连接
- python处理中文字符串的问题
- ArrayBlockingQueue源码解析
- git 自我学习详解
- SqlServer中,用exec处理sql字符串中含有变量,提示:必须声明标量变量@(已解决!)
- TCP中滑动窗口协议