(1)请求的重定向
HttpServletResponset接口提供的sendRedirect()方法用于生成302响应码和Location响应头,从而通知客户端去重新访问Location响应头中指定的URL,其完整的定义语法如下:
public void sendRedirect(String location) throws IOException;
其中的location参数指定了重定向的URL,它可以使用绝对URL和相对URL,Servlet容器会自动将相对URL转换成绝对URL后,再生成location头字段。
重定向的例子 response.sendRedirect(“secuse“);
注:重定向是两个servlet类结合而使用的,即是两次向服务器提交请求。一个servlet类不能完成操作,当用户运行到sendRedirect()时,会生成302响应码,意思是再次提交请求,在localtion的url的带领下,去访问secuess的servlet类,从而完成实现,但是在secuess中不能再次提交request的请求,否则返回的是null。因为每一次请求都是独一的。
(2)请求的分派
1.Servlet API中定义了一个RequestDispatcher接口,俗称请求分派器。它定义了如下两个方法:
(1)public void forward(ServletRequest request, ServletResponse response) throws ServletException,IOException;
(2)public void include(ServletRequest request, ServletResponse response) throws ServletException,IOException
2.请求的转发:
调用ServletContext接口提供的getRequestDispatcher(String url)方法。
调用ServletRequest接口提供的getRequestDispatcher(String url)方法
3.例子:
RequestDispatcher rd = request.getRequestDispatcher("fail");
//请求的转发,向前 ------------ 一个请求对象
rd.forward(request, response);
//请求的转发
rd.include(request, response);
forwrod和include的区别:forword是在页面跳转之后直接输出,不会再返回,而include则是把我当前的目录包含,输出
(3)两者比较:
1.请求转发只能是同一个web站点
重定向不仅可以定向到当前的web程序,还可以访问其他的站点的资源
2. 重定向在完成操作后,地址栏会发生变化,由初始的URL地址变成重定向的目标URL
请求转发过程结束后,浏览器地址栏保持初始的URL地址不变。
3.请求分派的发起者和被调用者之间共享相同的request实例和response实例,它们属于同一个“请求/响应”过程;而重定向的发起者和被调用者使用各自的request实例和response实例,它们各自属于独立的“请求/响应”过程