RequestDispatcher介绍
RequestDispatcher是一个Web资源的包装器,可以用来把当前request传递到该资源,或者把新的资源包括到当前响应中。RequestDispatcher接口中定义了两个方法:include/forward
由于<jsp:include>只能指定固定的jsp文件名,不能动态指定jsp文件名。我们需要把<jsp:include>翻译为Java code – RequestDispatcher.include();
用法: <% request.getRequestDispatcher(filename).include(request, response); />
服务器端的重定向可以有两种方式,一是使用HttpServletResponse的sendRedirect()方法,一是使用RequestDispatcher的forward()方法.
HttpServletResponse.sendRedirect()方法将响应定向到参数location指定的、新的。location可以是一个绝对的,如response.sendRedirect("http://java.sun.com")也可以使用相对的。如果location以“/”开头,则容器认为相对于当前Web应用的根,否则,容器将解析为相对于当前请求的。这种重定向的方法,将导致客户端浏览器的请求跳转。从浏览器中的地址栏中可以看到新的地址,作用类似于上面设置HTTP响应头信息的实现。
RequestDispatcher.forward()方法将当前的request和response重定向到该RequestDispacher指定的资源。这在实际项目中大量使用,因为完成一个业务操作往往需要跨越多个步骤,每一步骤完成相应的处理后,转向到下一个步骤。比如,通常业务处理在Servlet中处理,处理的结果转向到一个JSP页面进行显示。这样看起来类似于Servlet链的功能,但是还有一些区别。一个RequestDispatcher对象可以把请求发送到任意一个服务器资源,而不仅仅是另外一个Servlet。 include()方法将把Request Dispatcher资源的输出包含到当前输出中。
注意,只有在尚未向客户端输出响应时才可以调用forward()方法,如果页面缓存不为空,在重定向前将自动清除缓存。否则将抛出一个IllegalStateException异常。
request:
1、请求的服务器:<%=request.getServerName()%>
2、请求协议: <%=request.getProtocol()%>
3、请求方法: <%=request.getMethod()%>
4、请求端口号: <%=request.getServerPort()%>
5、Context路径: <%=request.getContextPath()%>
6、Servlet路径: <%=request.getServletPath()%>
7、URI路径: <%=request.getRequestURI()%>
8、查询字串: <%=request.getQueryString()%>
9、使用者主机IP:<%=request.getRemoteAddr()%>
10、使用者使用端口号:<%=request.getRemotePort()%>
response:
1、刷新,进入页面: response.setHeader("Refresh","3;"+member)
2、response响应生成图片
3、重定向 重定向是response的另一个用处,与forward不同的是,重定向会丢失所有的请求参数及请求属性。 response.sendRedirect("")
4、增加Cookie Cookie通常用于网站记录客户的某些信息,比如客户的用户以及客户的喜好等。一旦用户下次登陆,网站可以获取到客户的相关信息,根据这些客户信息,网站可以对客户提供更友好的服务。Cookie与session的不同之处在于:session关闭浏览器后就失效,但Cookie会一直存放在客户端机器上,除非超出Cookie的生命期限。
增加Cookie也是使用response内置对象完成的,response对象提供了一个方法。 void addCookie(Cookie cookie):增加Cookie.
创建Cookie:(1)创建Cookie实例;
(2)设置Cookie的生命期限;
(3)向客户端写Cookie
//获取请求参数
String name = request.getParameter("name");
//以获取到的请求参数为值,创建一个Cookie对象
Cookie c = new Cookie("username",name);
//设置Cookie对象的生命周期24小时
c.setMaxAge(24*3600);
response.addCookie(c);
通过getCookies()方法来访问Cookie //获取本站在客户端上保留的所有Cookie Cookie[] cookies = request.getCookies(); //遍历客户端上的每个Cookie for(Cookie c:cookies){ //如果Cookie的名为username,表明该Cookie是我们需要访问的Cookie if(c.getName().equals("username")) System.out.println(c.getValue()); }
session:
1、session.invalidate(): 可以让session事务失效
2、session.getId():获取session id
3、如果Cookie功能关闭,则session id无法存储,也就无法在下一次请求时一并送至伺服器,为了让进程追踪得以进行,您必须使用 rewriting来传送session id,使用response的encode()可以自动将session id编进中。
4、session.getMaxInactiveInterval():取得session的等待期限,取得的值以秒为单位
5、session.setMaxInactiveInterval():设定等待期限,设定的值也是以秒为单位
6、session的等待期限也可以在web.xml中设定