RequestDispatcher

RequestDispatcher是一个Web资源的包装器,可以用来把当前request传递到该资源,或者把新的资源包括到当前响应中。RequestDispatcher接口中定义了两个方法:include/forward


由于<jsp:include>只能指定固定的jsp文件名,不能动态指定jsp文件名。我们需要把<jsp:include>翻译为Java code – RequestDispatcher.include();


用法:
<% request.getRequestDispatcher(filename).include(request, response); />


服务器端的重定向可以有两种方式,一是使用HttpServletResponsesendRedirect()方法,一是使用RequestDispatcherforward()方法.


HttpServletResponse.sendRedirect()方法将响应定向到参数location指定的、新的。location可以是一个绝对的,如response.sendRedirect("http://java.sun.com")也可以使用相对的。如果location“/”开头,则容器认为相对于当前Web应用的根,否则,容器将解析为相对于当前请求的。这种重定向的方法,将导致客户端浏览器的请求跳转。从浏览器中的地址栏中可以看到新的地址,作用类似于上面设置HTTP响应头信息的实现。


RequestDispatcher.forward()方法将当前的requestresponse重定向到该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中设定


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值