一,内置对象简介
JSP内置对象:web容器创建的一组对象,不需要new关键字就可以使用的对象。
JSP九大内置对象:out,request,response,session,application,page,pageContext,exception,config(前五个最常用)
二,web 程序的请求与响应模式
web程序的请求响应模式
用户发送请求(request)
服务器给用户响应(response)
三,out对象
缓冲区:内存中用来保存临时数据的区域。
out对象:JspWriter类的实例,是向客户端输出内容常用的对象。
常用的方法:
1,void println() 向客户端打印字符串。
2,void clear() 清除缓存区的内容,如果在flush之后调用会抛出异常。
3,voidclearBuffer() 清除缓存区的内容,如果在flush之后调用不会抛出异常。
4,void flush() 将缓冲区内容输出到客户端。
5,int getBufferSize() 返回缓冲区一字节数的大小,如不设缓冲区则为0。
6,int getRemaining() 返回缓冲区还剩余多少可用。
7,boolean isAutoFlush() 返回缓冲区满时,是自动清空还是抛出异常
8,void close() 关闭输出流
四,get与post提交方式的区别
<form name="表达名" action="提交到的文件地址" method=“提交方式”></form>
表单有两种提交方式:get,post
1,get:以通过URL地址提交数据。提交的数据最多不超过2KB。安全性较低但效率比post方式高。适合提交数据量不大,安全性不高的数据。比如:搜索,查询等功能
2,post:将用户提交的信息封装在HTML HEADER内。适合提交数据量大,安全性高的用户信息。比如:注册,修改,上传等功能。
五,request 对象
客户端的请求信息被封装在request对象中,通过它才能了解到客户的需求,然后做出响应。他是HttpServletRequest类的实例。request对象具有请求域,即完成客户端的请求之前该对象一直有效。
常用方法:
1,String getParameter(String name)返回name指定参数的参数值。
2,String[] getParameterValues(String name) 返回包含参数name的所以值数组。
3,void setAttribute(String,Object) 存储此请求中的属性。
4,object getAttribute(String name) 返回指定属性的属性值
5,String getContentType() 得到请求体的MIME类型
6,String getProtocol() 返回请求用的协议类型及版本号
7,String getServerName() 返回接受请求的服务器主机名
8,int getServerPort() 返回服务器接受此请求所用的端口号
9,String getCharacterEncoding()返回字符编码方式
10,void setCharacterEncoding() 设置请求的字符编码方式
11,int getContentLength() 返回请求体的长度(以字节数)
12,String getRemoteAddr() 返回发送此请求的客户端IP地址
13,String getRealPath(String path) 返回一虚拟路径的真实路径
14,String request.getContextPath() 返回上下文路径
<%
request.setCharacterEncoding("utf-8"); //解决中文乱码问题,无法解决URL传递出现的乱码问题
request.setAttribute("password", "123456");
%>
大家好,我是<%=request.getParameter("username") %>,
我的爱好是<%
if(request.getParameterValues("like")!=null){
String[] like=request.getParameterValues("like");
for(int i=0;i<like.length;i++){
out.println(like[i]+",");
}
}
%>
密码:<%=request.getAttribute("password") %><br>
获得请求体的MIME类型:<%=request.getContentType() %><br>
返回请求用的协议类型及版本号:<%=request.getProtocol() %><br>
返回接受请求的服务器主机名:<%=request.getServerName() %><br>
返回服务器接受此请求所用的端口号:<%=request.getServerPort() %><br>
返回字符编码方式:<%=request.getCharacterEncoding() %><br>
返回请求体的长度(以字节数):<%=request.getContentLength() %><br>
返回发送此请求的客户端IP地址:<%=request.getRemoteAddr() %><br>
返回一虚拟路径的真实路径:<%=request.getRealPath("request.jsp") %><br>
返回上下文路径:<%=request.getContextPath() %>
六,response对象
response对象包含了响应客户请求的有关信息,但在JSP中很少直接使用到。它是HttpServletResponse类的实例。response对象具有页面作用域,即访问一个页面时,该页面内的response对象只能对这次访问有效,其它页面的response对象对当前页面无效。
常用的方法:
1.String getCharacterEncoding() 返回响应用时的字符编码
2,void setContentType(String type) 设置响应的MIME类型
3,PrintWriter getWriter() 返回可以向客户端输出字符的一个对象(注意:--1,使用PrintWriter前需导入java.io包; --2,Printwriter与内置out对象的区别在于PrintWriter会提前执行显示)
4,sendRedirect(java.lang,String location)重新定向客户端的请求。
<%@page import="java.io.PrintWriter"%>
<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<%
response.setContentType("text/html;charset=utf-8");//设置响应的MIME类型
out.println("<h1>response内置对象</h1>");
out.println("<hr>");
//out.flush();//强制清空缓存区,并把缓冲区的内容写(显示)出来
PrintWriter outer = response.getWriter();
outer.println("我是response对象生成的输出流outer对象");
response.sendRedirect("MyJsp.jsp");
%>
请求转发与请求重定向
请求转发:服务器行为,request.getRrquestDispatcher().forward(req,resp);是一次请求,转发后请求对象会保存,地址栏的URL地址不会改变。
request.getRequestDispatcher("request.jsp").forward(request, response);//请求转发
请求重定向:客户端行为,response.sendRedirect(),从本质上讲等同于两次请求,前一次请求对象不会保存,地址栏的URL会改变。
response.sendRedirect("request.jsp");//请求重定向
七,Session对象
web中的session就是客户浏览一个网站所用的时间(从客户打开浏览器并连接到服务器开始到客户关闭浏览器离开这个服务器结束)
当一个客户访问一个服务器时,可能会在服务器的几个页面之间切换,服务器应当通过某种办法知道这是一个客户,那就需要session对象
session是JSP内置对象 ,session对象在第一个JSP页面被装载时自动创建,完成会话期管理
session是HttpSession类的实例
session对象常用方法:
1,long getCreationTime() 返回session创建时间
2,public String getId() 返回session创建时JSP引擎为它设的唯一ID号
3,public Object setAttribute(String name,Object value) 使用指定名称将对象绑定到此会话。
4,public Object getAttribute(String name) 返回与此会话中的指定名称绑定在一起的对象,如果没有对象绑定在该名称下,则返回null。
5,String[] getValueNames() 返回一个包含此session种所以可用属性的数组。
6,int getMaxInactiveInterval() 返回两次请求间隔多少时间此session被取消(单位秒)。
session的生命周期:当客户端第一次访问某个JSP或servlet时候,服务器会为当前会话创建一个sessionId 每次客户端向服务端发送请求时,都会将此sessionID携带过去,服务端会对此sessionID进行校验。(当创建了新的会话不代表原有的会话就不存在了,旧的sessionID依然存在服务器中只是不会被客户端携带)
session销毁:
1,调用了session.invalidate()方法。
2,session过期(Tomcat默认session超时时间为30分钟)
------session超时有两种方式:
----------------1,session.setMaxInactiveInterval(时间);//秒
----------------2,在web.xml配置
<session-config><session-timeout>10</session-timeout></session-config>//单位分钟
3,服务器重新启动
热门评论
goodgoodgoodgoodgoodgoodgood