一、调用方式
我们知道,在servlet中调用转发,重定向的语句如下:
request.getRequestDispatcher("new.jsp").forward(request, response);//转发到new.jsp
response.sendRedirect("new.jsp");//重定向到new.jsp
在jsp页面中你也会看到通过如下方式实现转发:
<jsp:forward page="apage.jsp" />
<%response.sendRedirect("new.jsp");//重定向到new.jsp%>
二、本质区别
解释一
转发是服务器行为,重定向是客户端行为。为什么这样说呢,这要看这两个动作的工作流程:
转发过程:客户端浏览器发送http请求---》web服务器接受此请求--》调用内部的一个方法在容器内部完成请求处理和转发动作--》将目标资源发送给客户;在这里,转发的路径必须是同一个web容器下的url,其不能转向到其他的web路径上去,中间传递的是自己的容器内的request。在客户浏览器地址栏显示的仍然是其第一次访问的路径,也就是说客户感觉不到服务器做了转发的。转发行为是浏览器只做了一次访问请求。
重定向过程:客户浏览器发送http请求--》web服务器接受后发送302状态码响应及对应新的location给客户端浏览器--》客户端浏览器发现是302响应,则自动再发送一个新的http请求,请求url是新的location地址--》服务器据此请求寻找资源并发送给客户。在这里location可以重定向到任意的URL,既然是浏览器重新发出了请求,则就没有什么request传递的概念了。在客户端浏览器地址栏显示的是其重定向的路径,客户可以观察到的地址的变化的。重定向行为是浏览器做了至少两次的访问请求。
解释二
重定向,其实是两次request,第一次,客户端request A服务器响应,并reponse回来,告诉浏览器,你应该去B。这时候可以看到浏览器的地址栏地址变了,而且历史的回退按钮也亮了。重定向可以访问自己的web应用以外的资源。在重定向的过程中,传输的信息会被丢失。
请求转发,是服务器内部把对一个request/reponse的处理权移交给另外一个。对于客户端而言,它只知道自己最早请求的那个A,而不知道中间的B,甚至C,D。传输的信息不会丢失。