资源转载自网上,不可用于商用,学习可以。
内置对象又叫隐式对象/隐含对象是由WEB容器加载的一组类的实例,不需要预先声明就可以在脚本代码和表达式中随意使用的对象。
这九大隐式对象可以按照期作用分类为:
- 输入输出:request,response,out
- 作用域之间通信:session,application,pageContext,(request)
- Servlet对象:page,config
- 错误对象:Execpiton
4+2+3
四大作用域
(1)-->Application,也就是servlet中的 ServeletContext对象-->负责提供整个web项目在服务器中运行时的一些全局信息
生命周期:生命长度-->项目的加载到项目卸载
作用范围--->整个项目的所有servlet
(2)-->Session,也就是Servlet中的HttpSession对象---->代表服务器和客户端所建立的会话。当需要在不同的jsp文件中保留客户信息的情况下使用。比如在线购物,客户轨迹跟踪
生命周期:生命长度-->一次会话的长度【会话中断,强制销毁,超过最大不活动周期】
作用范围---->一个客户端只能由一个session,所有的servlet
(3)-->request,也就是httpservlet中的请求信息对象--->代表来自客户端的请求信息。例如form表单提交的参数。http请求行,请求头信息,请求实体内容等信息。还有cookie信息
生命周期:生命长度-->一次请求的长度
作用范围 --->所有被请求转发到的servlet
(4)-->pageContext,页面上下文对象,封装了当前jsp页面的运行信息。它提供了返回jsp页面的其他隐式对象的方法。
两大响应对象
(1)---->response,代表对客户端的响应。通过response对象来组织发送到客户端的数据。
(2)--->out,代表向客户端发送数据的对象。与response对象不同,它发送的内容都在页面中显示。
方法有print,println
clear,clearBuffer,flush,getBufferSize,getRemaining.这些方法是因为out对象内部包含一个缓冲区。
三个打酱油
(1)Config,配置对象。
(2)page,页面对象
(3)Exception,例外对象。
九大内置对象
内置对象 |
类型 |
说明 |
作用域 |
request |
javax.servlet.ServletRequest |
请求对象——在 一次请求/一个Request请求周期 中传递数据,请求结束后,数据不可访问,用于页面之间的值的传递 |
用户请求期 |
response |
javax.servlet.SrvletResponse |
响应对象——用来响应客户端请求并向客户端输出信息 |
页面执行期 |
out |
javax.servlet.jsp.JspWriter |
输出对象——表示输出流,该流将作为请求的响应发送到客户端 |
页面执行期 |
session |
javax.servlet.http.HttpSession |
会话对象——在一个session会话周期中,用于存储有关用户会话的所有信息 |
会话周期 |
application |
javax.servlet.ServletContext |
应用程序对象——用于实现用户之间的数据共享,负责提供应用程序在服务器中运行时的一些全局信息 |
整个程序运行期 |
pageContext |
javax.servlet.jsp.PageContext |
页面上下文对象——此对象提供所有四个作用域层次的属性查询和修改能力,它也提供了转发请求到其它资源和包含其他资源的方法 |
页面执行期 |
page |
javax.lang.Object |
页面对象——只在当前JSP页面内有效,提供对网页上定义的所有对象的访问,其表示的就是页面本身 |
页面执行期 |
config |
javax.servlet.ServletConfig |
配置对象——是ServletConfig的实例,代理当前jsp页面配置,提供配置信息 |
页面执行期 |
Execpiton |
javax.lang.Throwable |
例外对象——此对象指JSP文件运行时所产生的例外对象,也就是JSP引擎在执行代码时抛出的异常,此对象不能在一般JSP文件中直接使用,而只能在使用了“<%@ page isErrorPage="true"%>”的JSP文件中使用,也就是说只有在page指令中具有属性isErrorPage="true"时才有效 |
页面执行期 |
request 对象方法
返回类型 |
方法名称 |
说明 |
Object |
getAttribute(String name) |
返回由name指定的属性值,该属性不存在时返回null |
Enumeration |
getAttributeNames() |
返回request对象的所有属性名称的集合 |
String |
getAuthType() |
返回用来保护servlet的认证方法的名称,未受保护时返回null |
String |
getCharacterEncoding() |
返回请求中的字符编码方法,可以在response对象中设置 |
int |
getContentLength() |
返回请求的BODY的长度,不能确定长度时返回-1。可以在response中设置 |
String |
getContentType() |
返回在response中定义的内容类型 |
String |
getContentPath() |
返回请求的路径 |
Cookie[] |
getCookies() |
返回客户端所有的Cookie的数组 |
Enumeration |
getHeaderNames() |
返回所有HTTP头的名称的集合 |
Enumeration |
getHeaders(String name) |
返回指定HTTP头的所有值的集合 |
String |
getHeader(String name) |
返回指定名称的HTTP头的信息 |
long |
getDateHeader(String name) |
返回指定名称的Data类型的HTTP头的信息 |
int |
getIntHeader(String name) |
返回指定名称的Int类型的HTTP头的信息 |
ServletInputStream |
getInputStream() |
返回请求的输入流 |
Locale |
getLocale() |
返回当前页的Locale对象(此对象有两个方法,分别是getDisplayCountry和getDisplayLanguage),可以在response中设定 |
Enumeration |
getLocales() |
返回请求中所有的Locale对象的集合 |
String |
getLocalName() |
获取响应请求的服务器端主机名 |
String |
getLocalAddr() |
获取响应请求的服务器端地址 |
int |
getLocalPort() |
获取响应请求的服务器端端口 |
String |
getMethod() |
获取客户端向服务器端发送请求的方法(GET、POST) |
String |
getParameter(String name) |
获取客户端发送给服务器端的参数值 |
Map |
getParameterMap() |
该方法返回包含请求中所有参数的一个Map对象 |
Enumeration |
getParameterNames() |
返回请求中所有参数的集合 |
String[] |
getParameterValues(String name) |
获得请求中指定参数的所有值 |
String |
getQueryString() |
返回get方法传递的参数字符串,该方法不分解出单独的参数 |
String |
getPathInfo() |
取出请求中处于ServletPath和QueryString之间的额外信息 |
String |
getPathTranslated() |
返回用getPathInfo()方法取得的路径信息的实际路径 |
String |
getProtocol() |
返回请求使用的协议。可以是HTTP1.1或者HTTP1.0 |
BufferedReader |
getReader() |
返回请求的输入流对应的Reader对象,该方法和getInputStream()方法在一个页面中只能调用一个 |
String |
getRemoteAddr() |
获取发出请求的客户端IP地址 |
String |
getRemoteHost() |
获取发出请求的客户端主机名 |
String |
getRemoteUser() |
返回经过客户端验证的用户名,未经验证返回null |
int |
getRemotePort() |
返回发出请求的客户端主机端口 |
String |
getRealPath(String path) |
返回给定虚拟路径的物理路径 |
RequestDispatcher |
getRequestDispatcher(String path) |
按给定的路径生成资源转向处理适配器对象(转发) |
String |
getRequestedSessionId() |
返回请求的session的标识 |
String |
RequestURI() |
返回发出请求的客户端地址,但是不包括请求的参数字符串 |
StringBuffer |
getRequestURI() |
返回响应请求的服务器端地址 |
String |
getScheme() |
获取协议名称,缺省值为HTTP协议 |
String |
getServerName() |
返回响应请求的服务器名称 |
String |
getServletPath() |
获取客户端所请求的脚本文件的文件路径 |
int |
getServerPort() |
获取响应请求的服务器端主机端口号 |
void |
removeAttribute(String name) |
在属性列表中删除指定名称的属性 |
void |
setAttribute(String name, Object value) |
在属性列表中添加/删除指定的属性 |
void |
setCharacterEncoding(String charset) |
设置请求的字符编码格式 |
HttpSession |
getSession() | getSession(boolean create) |
获取session,如果create为true,在无session的情况下创建一个 |
boolean |
isRequestedSessionIdFromCookie() |
检查请求的会话ID是否为通过Cookie传入 |
boolean |
isRequestedSessionIdFromURL() |
检查请求的会话ID是否为通过URL传入 |
boolean |
isRequestedSessionIdValid() |
检查请求的会话ID是否仍然有效 |
boolean |
isSecure() |
检查请求是否使用安全链接,如果HTTPS等 |
boolean |
isUserInRole(String role) |
检查已经通过验证的用户是否在是role所指定的角色 |
Principal |
getUserPrincipal() |
返回包含用户登陆名的一个java.security.Principal对象 |
response 对象方法
返回类型 |
方法名称 |
说明 |
void |
addCookie(Cookie cookie) |
添加一个Cookie对象,保存客户端信息 |
void |
addDateHeader(String name, long value) |
添加一个日期类型的HTTP头信息,覆盖同名的HTTP头信息 |
void |
addHeader(String name, String value) |
添加一个HTTP头,覆盖同名的旧HTTP头 |
void |
addIntHeader(String name, int value) |
添加一个整型的HTTP头,覆盖同名的旧HTTP头 |
boolean |
containsHeader(String name) |
判断指定的HTTP头是否存在 |
String |
encodeRedirectURL(String url) |
对sendRedirect()方法使用的URL进行编码 |
String |
encodeURL(String url) |
将URL予以编码,回传包含session ID的URL |
void |
flushBuffer() |
强制把当前缓冲区的内容发送到客户端 |
int |
getBufferSize() |
取得以kb为单位的缓冲区大小 |
String |
getCharacterEncoding() |
获取响应的字符编码格式 |
String |
getContentType() |
获取响应的类型 |
Locale |
getLocale() |
获取响应的Locale对象 |
ServletOutputStream |
getOutputStream() |
返回客户端的输出流对象 |
PrintWriter |
getWriter() |
获取输出流对应的writer对象 |
boolean |
isCommitted() |
判断服务器端是否已经将数据输出到客户端 |
void |
reset() |
清空buffer中的所有内容 |
void |
sendError(int xc | int xc, String msg) |
发送错误,包括状态码和错误信息 |
void |
sendRedirect(String locationg) |
把响应发送到另外一个位置进行处理(转发) |
void |
setBufferSize(int size) |
设置以kb为单位的缓冲区大小 |
void |
setCharacterEncoding(String charset) |
设置响应使用的字符编码格式 |
void |
setContentLength(int length) |
设置响应的BODY长度 |
void |
setContentType(String type) |
设置响应的类型 |
void |
setDateHeader(String name, long value) |
设置指定名称的Data类型的HTTP头的值 |
void |
setHeader(String name, String value) |
设置指定名称的HTTP头的值 |
void |
setIntHeader(String name, int value) |
设置指定名称的int类型的HTTP头的值 |
void |
setStatus(int xc) |
设置响应状态码,新值会覆盖当前值 |
out 对象方法
返回类型 |
方法名称 |
说明 |
void |
clear() |
清除输出缓冲区的内容,但是不输出到客户端 |
void |
clearBuffer() |
清除输出缓冲区的内容,并输出到客户端 |
void |
close() |
关闭输出流,清除所有内容 |
void |
flush() |
输出缓冲区里面的数据 |
int |
getBufferSize() |
获取以kb为单位的目前缓冲区大小 |
int |
getRemaining() |
获取以kb为单位的缓冲区中未被占用的空间大小 |
boolean |
isAutoFlush() |
是否自动刷新缓冲区 |
void |
newLine() |
输出一个换行字符 |
void |
print(Object) |
将指定类型的数据输出到Http流,不换行 |
void |
println(Object) |
将指定类型的数据输出到Http流,并输出一个换行符 |
Appendable |
append(char c | CharSequence cxq, int start, int end | CharSequence cxq ) |
将一个字符或者实现了CharSequence接口的对象添加到输出流的后面 |
session 对象方法
返回类型 |
方法名称 |
说明 |
Object |
getAttribute(String name) |
获取与指定名字相关联的session属性值 |
Enumeration |
getAttributeNames() |
取得session内所有属性的集合 |
long |
getCreationTime() |
返回session的创建时间,最小单位千分之一秒 |
String |
getId() |
取得session标识 |
long |
getLastAccessedTime() |
返回与当前session相关的客户端最后一次访问的时间,由1970-01-01算起,单位毫秒 |
int |
getMaxInactiveInterval(int interval) |
返回总时间,以秒为单位,表示session的有效时间(session不活动时间)。-1为永不过期 |
ServletContext |
getServletContext() |
返回一个该JSP页面对应的ServletContext对象实例 |
HttpSessionContext |
getSessionContext() |
返回与会话标识符关联的会话 |
Object |
getValue(String name) |
取得指定名称的session变量值,不推荐使用 |
String[] |
getValueNames() |
取得所有session变量的名称的集合,不推荐使用 |
void |
invalidate() |
销毁这个session对象 |
boolean |
isNew() |
判断一个session是否由服务器产生,但是客户端并没有使用 |
void |
pubValue(String name, Object value) |
添加一个session变量,不推荐使用 |
void |
removeValue(String name) |
移除一个session变量的值,不推荐使用 |
void |
setAttribute(String name, String value) |
设置指定名称的session属性值 |
void |
setMaxInactiveInterval(int interval) |
设置session的有效期 |
void |
removeAttribute(String name) |
移除指定名称的session属性 |
application 对象方法
返回类型 |
方法名称 |
说明 |
Object |
getAttribute(String name) |
返回由name指定的application属性 |
Enumeration |
getAttributes() |
返回所有的application属性 |
ServletContext |
getContext(String uripath) |
取得当前应用的ServletContext对象 |
String |
getInitParameter(String name) |
返回由name指定的application属性的初始值 |
Enumeration |
getInitParameters() |
返回所有的application属性的初始值的集合 |
int |
getMajorVersion() |
返回servlet容器支持的Servlet API的版本号 |
String |
getMimeType(String file) |
返回指定文件的类型,未知类型返回null。一般为"text/html"和"image/gif"。 |
int |
getMinorVersion() |
返回servlet容器支持的Servlet API的副版本号 |
String |
getRealPath(String path) |
返回给定虚拟路径所对应物理路径 |
RequestDispatcher |
getNamedDispatcher(String name) |
为指定名字的Servlet对象返回一个RequestDispatcher对象的实例 |
RequestDispatcher |
getRequestDispatcher(String path) |
返回一个RequestDispatcher对象的实例 |
URL |
getResource(String path) |
返回指定的资源路径对应的一个URL对象实例,参数要以"/"开头 |
InputStream |
getResourceAsStream(String path) |
返回一个由path指定位置的资源的InputStream对象实例 |
Set |
getResourcePaths(String path) |
返回存储在web-app中所有资源路径的集合 |
String |
getServerInfo() |
取得应用服务器版本信息 |
Servlet |
getServlet(String name) |
在ServletContext中检索指定名称的servlet |
Enumeration |
getServlets() |
返回ServletContext中所有servlet的集合 |
String |
getServletContextName() |
返回本web应用的名称 |
Enumeration |
getServletContextNames() |
返回ServletContext中所有servlet的名称集合 |
void |
log(Exception ex, String msg | String msg, Throwable t | String msg) |
把指定的信息写入servlet log文件 |
void |
removeAttribute(String name) |
移除指定名称的application属性 |
void |
setAttribute(String name, Object value) |
设定指定的application属性的值 |
pageContext 对象方法
返回类型 |
方法名称 |
说明 |
void |
setAttribute(String name, Object value, int scope | String name, Object value) |
在指定的共享范围内设置属性 |
Object |
getAttribute(String name, int scope | String name) |
取得指定共享范围内以name为名字的属性值 |
Object |
findAttribute(String name) |
按页面、请求、会话和应用程序共享范围搜索已命名的属性 |
void |
removeAttribute(String name, int scope | String name) |
移除指定名称和共享范围的属性 |
void |
forward(String url) |
将页面导航到指定的URL |
Enumeration |
getAttributeNamesScope(int scope) |
取得指定共享范围内的所有属性名称的集合 |
int |
getAttributeScope(String name) |
取得指定属性的共享范围 |
ErrorData |
getErrorDate() |
取得页面的errorData对象 |
Exception |
getException() |
取得页面的exception对象 |
ExpressionEvaluator |
getExpressionEvaluator() |
取得页面的expressionEvaluator对象 |
JspWriter |
getOut() |
取得页面的out对象 |
Object |
getPage() |
取得页面的page对象 |
ServletRequest |
getRequest() |
取得页面的request对象 |
ServletResponse |
getResponse() |
取得页面的response对象 |
ServletConfig |
getConfig() |
取得页面的config对象 |
ServletContext |
getServletContext() |
取得页面的servletContext对象 |
HttpSession |
getSession() |
取得页面的session对象 |
VariableResolver |
getVariableResolver() |
取得页面的variableResolver对象 |
void |
include(String url, boolean flush | String url) |
包含其他的资源,并指定是否自动刷新 |
void |
release() |
重置pageContext内部状态,释放所有内部引用 |
void |
initialize( Servlet servlet, ServletRequest request, ServletResponse response,String errorPageURL, boolean needSession, int bufferSize, boolean autoFlush ) |
初始化未经初始化的pageContext对象 |
BodyContext |
pushBody() | pushBody(Writer writer) |
保存当前的out对象,并更新pageContext中page范围内的out对象 |
JspWrite |
popBody() |
取出由pushBody()方法保存的out对象 |
void |
handlePageException(Exception e | Thrwoable t) |
此方法将异常重定向到 JSP 的错误页,如果没有指定错误页的话,则执行一些依赖于实现的操作来处理该异常 |
config 对象方法
返回类型 |
方法名称 |
说明 |
String |
getInitParameter(String name) |
返回名称为name的促使参数的值 |
Enumeration |
getInitParameters() |
返回这个JSP所有的促使参数的名称集合 |
ServletContext |
getContext() |
返回执行者的servlet上下文 |
String |
getServletName() |
返回servlet的名称 |
exception 对象方法
返回类型 |
方法名称 |
说明 |
Throwable |
fillInStackTrace() |
将当前stack信息记录到exception对象中 |
String |
getLocalizedMessage() |
取得本地语系的错误提示信息 |
String |
getMessage() |
取得错误提示信息 |
StackTrackElement[] |
getStackTrace() |
返回对象中记录的call stack track信息 |
Throwable |
initCause(Throwable cause) |
将另外一个异常对象嵌套进当前异常对象中 |
Throwable |
getCause() |
取出嵌套在当前异常对象中的异常 |
void |
printStackTrace() | printStackTrace(printStream s) | printStackTrace(printWriter s) |
打印出Throwable及其call stack trace信息 |
void |
setStackTrace(StackTraceElement[] stackTrace) |
设置对象的call stack trace信息 |