什么是内置对象?
一句话解释:自带,不需要new 也能使用的对象
1 JSP的九个内置对象
JSP中一共预先定义了9个这样的对象,分别为:request、response、session、application、out、pagecontext、config、page、exception
1.1 request对象
request 对象是 javax.servlet.httpServletRequest类型的对象。 该对象代表了客户端的请求信息,主要用于接受通过HTTP协议传送到服务器的数据。(包括头信息、系统信息、请求方式以及请求参数等)。request对象的作用域为一次请求。
1.2 response对象
response 代表的是对客户端的响应,主要是将JSP容器处理过的对象传回到客户端。response对象也具有作用域,它只在JSP页面内有效。
1.3 session对象
session 对象是由服务器自动创建的与用户请求相关的对象。服务器为每个用户都生成一个session对象,用于保存该用户的信息,跟踪用户的操作状态。session对象内部使用Map类来保存数据,因此保存数据的格式为 “Key/value”。 session对象的value可以使复杂的对象类型,而不仅仅局限于字符串类型。
1.4 application对象
application 对象可将信息保存在服务器中,直到服务器关闭,否则application对象中保存的信息会在整个应用中都有效。与session对象相比,application对象生命周期更长,类似于系统的“全局变量”。
1.5 out 对象
out 对象用于在Web浏览器内输出信息,并且管理应用服务器上的输出缓冲区。在使用 out 对象输出数据时,可以对数据缓冲区进行操作,及时清除缓冲区中的残余数据,为其他的输出让出缓冲空间。待数据输出完毕后,要及时关闭输出流。
1.6 pageContext 对象
pageContext 对象的作用是取得任何范围的参数,通过它可以获取 JSP页面的out、request、reponse、session、application 等对象。pageContext对象的创建和初始化都是由容器来完成的,在JSP页面中可以直接使用 pageContext对象。
1.7 config 对象
config 对象的主要作用是取得服务器的配置信息。通过 pageConext对象的 getServletConfig() 方法可以获取一个config对象。当一个Servlet 初始化时,容器把某些信息通过 config对象传递给这个 Servlet。 开发者可以在web.xml 文件中为应用程序环境中的Servlet程序和JSP页面提供初始化参数。
1.8 page 对象
page 对象代表JSP本身,只有在JSP页面内才是合法的。 page隐含对象本质上包含当前 Servlet接口引用的变量,类似于Java编程中的 this 指针。
1.9 exception 对象
exception 对象的作用是显示异常信息,只有在包含 isErrorPage=“true” 的页面中才可以被使用,在一般的JSP页面中使用该对象将无法编译JSP文件。excepation对象和Java的所有对象一样,都具有系统提供的继承结构。exception 对象几乎定义了所有异常情况。在Java程序中,可以使用try/catch关键字来处理异常情况; 如果在JSP页面中出现没有捕获到的异常,就会生成 exception 对象,并把 exception 对象传送到在page指令中设定的错误页面中,然后在错误页面中处理相应的 exception 对象。
2 使用详解
2.1 request对象
2.1.1 常用方法:
String getParameter(String name)
:
根据请求的字段名key (input标签的name属性值) ,返回字段值value (input标签的value属性值)String[] getParameterValues(String name)
:
根据请求的字段名key ,返回多个字段值value (checkbox)void setCharacterEncoding("编码格式utf-8")
:
设置post方式的请求编码 (tomcat7以前默认iso-8859-1,tomcat8以后改为了utf-8)getRequestDispatcher("b.jsp").forward(request,response)
:
请求转发 的方式跳转页面 A - > B,转到b.jsp .forward(request,response)为固定格式ServletContext getServerContext():
获取项目的ServletContext对象
2.1.2 举例(登录请求)
Login.jsp登录界面
<body> <form action="tesLogin.jsp" method="post"> <input type="text" name = "mname"> <input type="text" name = "mpwd"> <input type="submit" value="登录"> </form> </body> 复制代码
tesLogin.jsp处理界面
String mname=request.getParameter("mname"); String mpwd =request.getParameter("mpwd"); request.getRequestDispatcher("/Welcome.html").forward(request,response); 复制代码
示例2:(注册 register.jsp show.jsp)
register.jsp
show.jsp
2.1.3 提交方式
get提交方式: method=“get” 和 地址栏 、超链接(<a href=“xx”>)请求方式 默认都属于get提交方式
2.1.4 get与post请求方式的区别:
- get方式 在地址栏显示 请求信息 (但是地址栏能够容纳的 信息有限,4-5KB;如果请求数据存在大文件,图片等 会出现地址栏无法容纳全部的数据而出错) ;post不会显示
- 文件上传操作,必须是post
2.2 response响应对象
2.2.1 方法
response :响应对象—提供的方法:
- void addCookie( Cookie cookie );
服务端向客户端增加cookie对象 - void sendRedirect(String location ) throws IOException; :
页面跳转的一种方式(重定向) - void setContetType(String type):
设置服务端响应的编码(设置服务端的contentType类型)
2.2.2 举例
<body> <% out.print("两次输入密码必须一样"); Cookie c=null; response.sendRedirect("login.jsp"); response.addCookie(c); %> </body> 复制代码
注:response.sendRedirect(“login.jsp”);提交到另一个页面时,数据会丢失。
2.2.3 转发request和重定向response
- 转发: request.getRequestDispatcher(“success.jsp”).forward( request,response);
张三(客户端) -> 【 服务窗口 A (服务端 ) -> 服务窗口B 】 - 重定向:
response.sendRedirect(“success.jsp”) ;//页面跳转:重定向, 导致数据丢失
张三(客户端) -> 服务窗口 A (服务端 ) ->去找B
张三(客户端) -> 服务窗口 B (服务端 ) ->结束
2.3 session服务端对象
2.3.1 先介绍cookie
Cookie(客户端,不是内置对象):Cookie是由 服务端生成的 ,再发送给客户端保存。
相当于 本地缓存的作用: 客户端(hello.mp4,zs/abc)->服务端(hello.mp4;zs/abc)
作用:提高访问服务端的效率,但是安全性较差。
2.3.2 cookie方法:
Cookie: name=value
javax.servlet.http.Cookie
public Cookie(String name,String value)
String(返回值) getName():获取name
String getValue():获取value
void setMaxAge(int expiry);最大有效期 (秒)
服务端准备Cookie:
response.addCookie(Cookie cookie)
页面跳转(转发,重定向)
客户端获取cookie: request.getCookies();
a.服务端增加cookie :response对象;客户端获取对象:request对象
b.不能直接获取某一个单独对象,只能一次性将 全部的cookie拿到
通过F12可以发现 除了自己设置的Cookie对象外,还有一个name为 JSESSIONID的cookie
建议 cookie只保存 英文数字,否则需要进行编码、解码
2.3.3 cookie示例:使用Cookie实现 记住用户名 功能
Result.jsp
Response.jsp
2.3.4 session :中文翻译(会话)
例如:
- a.浏览网站:开始-关闭
- b.购物:浏览、付款、退出
- c.电子邮件:浏览、写邮件、退出
2.3.5 session机制:
- 客户端第一次请求服务端时,(jsessionid-sessionid)服务端会产生一个session对象(用于保存该客户的信息); 并且每个session对象 都会有一个唯一的 sessionId( 用于区分其他session);
- 服务端由会 产生一个cookie,并且 该cookie的name=JSESSIONID ,value=服务端sessionId的值;然后 服务端会在 响应客户端的同时 将该cookie发送给客户端,至此 客户端就有了 一个cookie(JSESSIONID);因此,客户端的cookie就可以和服务端的session一一对应(JSESSIONID - sessionID)
- 客户端第二/n次请求服务端时:服务端会先用客户端cookie种的JSESSIONID 去服务端的session中匹配sessionid,如果匹配成功(cookie jsessionid和sesion sessionid),说明此用户 不是第一次访问,无需登录;
例子:
客户端: 顾客(客户端)
服务端: 存包处 - 商场(服务端)
顾客第一次存包:商场 判断此人是 之前已经存过包(通过你手里是否有钥匙)。
如果是新顾客(没钥匙) ,分配一个钥匙 给该顾客; 钥匙 会和 柜子 一一对应;
第二/n次 存包:商场 判断此人是 之前已经存过包(通过你手里是否有钥匙)
如果是老顾客(有钥匙),则不需要分配;该顾客手里的钥匙 会 和柜子 自动一一对应。
2.3.6 *session:原理解释
- session存储在服务端
- session是在 同一个用户(客户)请求时 共享
- 实现机制:第一次客户请求时 产生一个sessionid 并复制给 cookie的jsessionid 然后发给客户端。最终 通过session的sessionid-cookie的jsessionid
2.3.7 session方法:
- String getId() :获取sessionId
- boolean isNew() :判断是否是 新用户(第一次访问)
- void invalidate():使session失效 (退出登录、注销)
- void setAttribute() 增加session对象
- Object getAttribute(); 返回值可强制转换(String)
- void setMaxInactiveInterval(秒) :设置最大有效 非活动时间
- int getMaxInactiveInterval():获取最大有效 非活动时间
2.3.8 session示例:用户登录
Login.jsp
Check.jsp
Welcome.jsp
Invalidate.jsp
A.Jsp
结果;
2.3.9 *cookie和session的区别
2.4 appliation 全局对象
2.4.1 方法:
- String getContextPath()
虚拟路径 - String getRealPath(String name):
绝对路径(虚拟路径 相对的绝对路径)
2.5.2 示例:
部分内容来源自网络,仅为学习交流使用,如有侵权请联系删除