`

web请求转发与重定向的区别

阅读更多

重定向与转发的区别:
1.重定向访问服务器两次,转发只访问服务器一次。
2.重定向可以看见目标页面的URL,转发只能看见第一次访问的页面URL,以后的工作都是有服务器来做的。
3.重定向跳转后必须加上return,要不然页面虽然跳转了,但是还会执行跳转后面的语句,转发是执行了跳转页面,下面的代码就不会在执行了。
4.在request级别使用信息共享,使用重定向必然出错

5.还有一个大的区别就是,重定向可以访问自己web应用以外的资源

 

一、调用方式 

我们知道,在servlet中调用转发、重定向的语句如下: 
request.getRequestDispatcher("new.jsp").forward(request, response);//转发到new.jsp 
response.sendRedirect("new.jsp");//重定向到new.jsp 

在jsp页面中你也会看到通过下面的方式实现转发: 
<jsp:forward page="apage.jsp" /> 

当然也可以在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,服务器响应,并response回来,告诉浏览器,你应该去B。这个时候IE可以看到地址变了,而且历史的回退按钮也亮了。重定向可以访问自己web应用以外的资源。在重定向的过程中,传输的信息会被丢失。 

请求转发是服务器内部把对一个request/response的处理权,移交给另外一个 
对于客户端而言,它只知道自己最早请求的那个A,而不知道中间的B,甚至C、D。 传输的信息不会丢失。 

例子: 

解释三 
假设你去办理某个执照, 

重定向:你先去了A局,A局的人说:“这个事情不归我们管,去B局”,然后,你就从A退了出来,自己乘车去了B局。 

转发:你先去了A局,A局看了以后,知道这个事情其实应该B局来管,但是他没有把你退回来,而是让你坐一会儿,自己到后面办公室联系了B的人,让他们办好后,送了过来。 

三、请求重定向与请求转发的比较 

尽管HttpServletResponse.sendRedirect方法和RequestDispatcher.forward方法都可以让浏览器获得另外一个URL所指向的资源,但两者的内部运行机制有着很大的区别。下面是HttpServletResponse.sendRedirect方法实现的请求重定向与RequestDispatcher.forward方法实现的请求转发的总结比较: 

(1)RequestDispatcher.forward方法只能将请求转发给同一个WEB应用中的组件;而HttpServletResponse.sendRedirect 方法不仅可以重定向到当前应用程序中的其他资源,还可以重定向到同一个站点上的其他应用程序中的资源,甚至是使用绝对URL重定向到其他站点的资源。如果传递给HttpServletResponse.sendRedirect 方法的相对URL以“/”开头,它是相对于整个WEB站点的根目录;如果创建RequestDispatcher对象时指定的相对URL以“/”开头,它是相对于当前WEB应用程序的根目录。 

(2)调用HttpServletResponse.sendRedirect方法重定向的访问过程结束后,浏览器地址栏中显示的URL会发生改变,由初始的URL地址变成重定向的目标URL;而调用RequestDispatcher.forward 方法的请求转发过程结束后,浏览器地址栏保持初始的URL地址不变。 

(3)HttpServletResponse.sendRedirect方法对浏览器的请求直接作出响应,响应的结果就是告诉浏览器去重新发出对另外一个URL的 访问请求,这个过程好比有个绰号叫“浏览器”的人写信找张三借钱,张三回信说没有钱,让“浏览器”去找李四借,并将李四现在的通信地址告诉给了“浏览器”。于是,“浏览器”又按张三提供通信地址给李四写信借钱,李四收到信后就把钱汇给了“浏览器”。可见,“浏览器”一共发出了两封信和收到了两次回复, “浏览器”也知道他借到的钱出自李四之手。RequestDispatcher.forward方 法在服务器端内部将请求转发给另外一个资源,浏览器只知道发出了请求并得到了响应结果,并不知道在服务器程序内部发生了转发行为。这个过程好比绰号叫“浏览器”的人写信找张三借钱,张三没有钱,于是张三找李四借了一些钱,甚至还可以加上自己的一些钱,然后再将这些钱汇给了“浏览器”。可见,“浏览器”只发 出了一封信和收到了一次回复,他只知道从张三那里借到了钱,并不知道有一部分钱出自李四之手。 

(4)RequestDispatcher.forward方法的调用者与被调用者之间共享相同的request对象和response对象,它们属于同一个访问请求和响应过程;而HttpServletResponse.sendRedirect方法调用者与被调用者使用各自的request对象和response对象,它们属于两个独立的访问请求和响应过程。对于同一个WEB应用程序的内部资源之间的跳转,特别是跳转之前要对请求进行一些前期预处理,并要使用HttpServletRequest.setAttribute方法传递预处理结果,那就应该使用RequestDispatcher.forward方法。不同WEB应用程序之间的重定向,特别是要重定向到另外一个WEB站点上的资源的情况,都应该使用HttpServletResponse.sendRedirect方法。 

(5)无论是RequestDispatcher.forward方法,还是HttpServletResponse.sendRedirect方法,在调用它们之前,都不能有内容已经被实际输出到了客户端。如果缓冲区中已经有了一些内容,这些内容将被从缓冲区中清除。

分享到:
评论

相关推荐

    javaweb转发和重定向

    javaweb请求转发的简单实例,演示了forward()方法和getRequestDispatcher()的不同之处

    页面转向与重定向

    请求转发和重定向在页面跳转时数据的传递,为什么重定向会丢失数据,之间到底有什么区别。

    SpringMVC核心技术精讲.docx

    当处理器对请求处理完毕后,向其它资源进行跳转时,有两种跳转方式:请求转发与重定向。而根据所要跳转的资源类型,又可分为两类:跳转到页面与跳转到其它处理器 注意,对于请求转发的页面,可以是WEB-INF中页面;而...

    基于框架的Web开发-处理数据模型、转发和重定向.docx

    5.4 处理模型数据、转发和重定向 Spring MVC通过@RequestMapping注解将请求引导到处理方法上,并可以将请求消息绑定到方法的参数上。将请求绑定到方法上只是处理的第一步,方法还要执行相应的逻辑运算,产生模型数据...

    Servlet+jsp.docx

    创建web工程还有代码是试练,请求方式+重定向+请求转发+cookie+session+jsp(四大作用域九大内置对象)

    java web总结

    java web总结请求转发 请求重定向

    Java Web中的页面跳转.pdf

    在java Web编程中间经常出现需要从一个页面跳转到另外一个页面,如何选择跳转方式一直是java Web编程...本文总结了JSP/Servlet、Struts2和Spring中的页面跳转方法,详细分析对比了请求转发和重定向、RequestDispatc...

    Web 常见面试题

    3. http 中重定向和请求转发的区别(8个) 4. Cookie 和 Session
区别 5. 什么是 jsp,什么是 Servlet?jsp 和 Servlet 有什么区别? 6. jsp 有哪些域对象和内置对象及他们的作用 7. 过滤器和监听器是什么,有什么用...

    深入体验Java Web开发内幕

    5.1 准备实验环境  5.2 HttpServletResponse简介  5.3 产生响应状态行  5.4 构建响应消息头  5.5 响应消息头的实用案例  5.6 创建响应正文  5.7 请求重定向与请求转发  5.8 思考与实践...

    nginx目录路径重定向的方法

    如果希望域名后边跟随的路径指向本地磁盘的其他目录,而不是默认的web目录时,需要设置nginx目录访问重定向. 应用场景:dashidan.com/image自动跳转到dashidan.com/folderName/image.nginx目录路径重定向的四种实现方式...

    java-web小Demo

    其中包括:请求编码,响应编码,转发,包含,重定向;

    JSP和Servlet面试题

    重定向时服务器产生两次请求,转发产生一次请求,重定向时可以转发到项目以外的任何网址,转发只能在当前项目里转发 重定向会导致request对象信息丢失。转发则不会 转发的url不会变,request.getRequestDispatch()...

    Java Web编程宝典-十年典藏版.pdf.part2(共2个)

    2.6.2 使用请求转发的动作标识 2.6.3 子动作标.iR~使用 2.7 实战检验 2.7.1 输出九九乘法表 2.7.2 JSP中实现随机抽奖 2.8 疑难解惑 2.8.1 在JSP页面中编写中文之后不能保存 2.8.2 访问JSP页面出现乱码 2.8.3 在JSP...

    Java Web应用开发:关于路径.docx

    是服务端转发请求给服务端另一组件,或者包含另一服务端组件的路径。 1.2 绝对路径和相对路径 1.2.1 绝对路径 绝对路径以“/”开头,(如果是http://****这种完整的地址也算绝对路径,这种路径容易理解,我们不讨论...

    cpp-Nginx静态资源重定向模块

    本模块可以将当前域下静态文件(css, js, img)重写URL来转发至另一台web服务器请求.

    conversor-monetario

    货币转换器-第一次实用Web评估4 申请进行货币兑换线框: Quant-UX( )检查清单: 转发和重定向 在MVC模型之外使用转发(即,一个servlet将请求转发到另一个servlet)。 技巧是将复杂的处理分为两个步骤,即两个...

    JavaWeb实战开发

    请求方式的编码问题、response、请求转发和重定向、cookie、session执行机制、session共享问题? ? ?4.session与cookie问题及application、cookie补充说明及四种范围对象作用域? ? ?5.JDBC原理及使用Statement访问...

    Spring基础 IOC入门

    监听器、过滤器(springMVC中被拦截器)、请求转发和重定向(springMVC的跳转替代) 2.Spring基础 2.1Spring简述 为什么要讲解spring: 传统项目优点:搭建容易 传统项目缺点:1、service、dao 对象都是程序员手动...

    php-proxy:简单PHP代理脚本

    简单PHP代理该代理脚本允许您将所有HTTP / HTTPS请求转发到另一台服务器。 适用于所有常见请求类型,包括GET,带有文件的POST请求,PATCH和PUT请求。 它具有最少的要求集(PHP&gt; = 5.6,libcurl,gzip),即使在最小...

    Proxy-Updater-:Proxy-Updater ++从webshare.io创建静态本地IP到您的旋转代理

    从main.h中的webshare.io用您的API更改APIKey而不是打开程序,它将创建以127.0.0.x:9000开头的静态IP,仅在程序中使用这些IP,所有请求都将重定向到当前代理服务器的IP。 该程序每2分钟检查一次新代理。 确保您是...

Global site tag (gtag.js) - Google Analytics