重定向和转发的区别【转】

news/2025/3/22 2:02:53
一、调用方式


我们知道,在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的人,让他们办好后,送了过来。

https://dhexx.cn/news/show-2339567.html

相关文章

VBox 对网络模式 增强

在之前的Blog里提到了VBox 的4中网络类型&#xff1a; NAT Bridged Adapter Internal Host-onlyAdapter 具体参考&#xff1a; Oracle Virtual Box 安装使用 说明 http://www.cndba.cn/Dave/article/635 今天升级了一个VBox 到4.1.8&#xff0c;在这个版本中对网络这块有…

对团队诠释比较好的文章【转】

[aligncenter][sizelarge][colorbrown]我一直坚信只有完美的团队&#xff0c;没有完美的个人&#xff01;[/color][/size][/align]首先&#xff0c;就是团队精神。凡是能够取得骄人业绩的团队&#xff0c;无一不是具有团队精神的。在这几年的销售职业生涯里&#xff0c;让我深刻…

Oracle PL/SQL 概述

官网的链接&#xff1a; Overview of PL/SQL http://docs.oracle.com/cd/E11882_01/appdev.112/e25519/overview.htm Server-Side Programming: PL/SQL and Java http://docs.oracle.com/cd/E11882_01/server.112/e25789/srvrside.htm 一.PL/SQL 定义 PL/SQL is theOracle D…

Hibernate-核心接口

[b][colorred] Session 接口[/color][/b] Session 接口对于Hibernate 开发人员来说是一个最重要的接口。然而在Hibernate 中&#xff0c;实例 化的Session是一个轻量级的类&#xff0c;创建和销毁它都不会占用很多资源。这在实际项目中确实很重要&#xff0c; 因为在客户程序中…

Oracle Alerts 与 Metrics(警告与度量)说明

一.Alerts 和 Metrics说明 官方链接&#xff1a; Monitoring and Tuning the Database http://docs.oracle.com/cd/E11882_01/server.112/e10897/montune.htm#CACCIHAB Alerts help you monitor your database. Most alerts notify youof when particular metric thresholds…

Javascript学习进阶——JS之美 [转]

var a[-1,-2,-3,5,6,-1];function f(s,e){ var ret[]; for(var i in s) { ret.push(e(s[i])); } return ret;}var bf(a,function(n){return n>0?n:0});alert(b);//result://0,0,0,5,6,0

Oracle dbca Exception in thread “main” 解决方法

在一套DB服务器上运行DBCA 命令&#xff0c;报错&#xff1a; [oraclegame_db ~]$ dbca Exception in thread "main" [oraclegame_db ~]$ [oraclegame_db ~]$ exportDISPLAY1921.68.3.189:0.0 [oraclegame_db ~]$ dbca Exception in thread "main" …

Oracle Expdp/Impdp 进行数据迁移的 几点注意事项

关于Expdp/Impdp 命令的具体使用&#xff0c;在之前的blog里有说明&#xff0c;参考&#xff1a; Oracle expdp/impdp 使用示例 http://www.cndba.cn/Dave/article/1411 exp/imp 与 expdp/impdp 对比 及使用中的一些优化事项 http://www.cndba.cn/Dave/article/1428 Oracle …

生活了多少天

一万天 SELECT ROUND(TO_NUMBER(TO_DATE(2010-06-21, yyyy-MM-dd) - TO_DATE(1983-02-03, yyyy-MM-dd))) FROM DUAL SELECT ROUND(TO_NUMBER(SYSDATE - TO_DATE(1983-02-03, yyyy-MM-dd))) FROM DUAL

Oracle Resumable Space Allocation 特性 说明

一.Resumable Space Allocation 说明 从9i开始&#xff0c;Oracle提供了一种避免因为space Error而导致事务异常的操作: resumable spaceallocation. 在Oracle 10g的OCP 考试中有考resumable session 的这个知识点。 官网对Resumable的解释&#xff1a; Advantage is forDBA…