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中设定

posted on 2012-11-21 22:38  一笑之奈何  阅读(1673)  评论(0编辑  收藏  举报