本文转自forward和redirect的区别是什么?

1:概念

forward和redirect是servlet中的两种主要的跳转方式。forward又叫转发(直接转发),redirect叫做重定向(间接转发)。

2:区别

  • 地址栏
  • 数据共享
  • 应用场景
  • 效率
  • 本质
  • 转发次数。
  1. 从地址栏显示来说:

    • forword是服务器内部的重定向,服务器直接访问目标地址的 url 网址,把里面的东西读取出来,但是客户端并不知道,因此用forward的话,客户端浏览器的网址是不会发生变化的。

    • redirect是服务器根据逻辑,发送一个状态码,告诉浏览器重新去请求那个地址,所以地址栏显示的是新的地址

  2. 从数据共享来说:

    • 由于在整个定向的过程中用的是同一个request,因此forward会将request的信息带到被重定向的jsp或者servlet中使用。即可以共享数据

    • redirect不能共享

  3. 从运用的地方来说:

    • forword 一般用于用户登录的时候,根据角色转发到相应的模块

    • redirect一般用于用户注销登录时返回主页面或者跳转到其他网站

  4. 从效率来说:

    forword效率高,而redirect效率低

  5. 从本质来说:
    forword转发是服务器的行为,而redirect重定向是客户端的行为

    • 转发过程:客户浏览器发送http请求–web服务器接受此请求–调用内部的一个方法在容器内部完成请求处理和转发动作–将目标资源发送给客户。
      在这里,转发的路径必须是同一个web容器下的url,其不能转向到其他的web路径上去,中间传递的是自己的容器内的request。在客户浏览器路径栏显
      示的仍然是其第一次访问的路径,也就是说客户是感觉不到服务器做了转发的。转发行为是浏览器只做了一次访问请求。
    • 重定向过程:客户浏览器发送http请求–web服务器接受后发送302状态码响应及对应新的location给客户浏览器–客户浏览器发现是302响应,则自动再发送一个新的http请求,请求url是新的location地址–服务器根据此请求寻找资源并发送给客户。
      在这里location可以重定向到任意URL,既然是浏览器重新发出了请求,则就没有什么request传递的概念了。在客户浏览器路径栏显示的是其重定向的路径,客户可以观察到地址的变化的。
      重定向行为是浏览器做了至少两次的访问请求的。
  6. 从请求的次数来说:
    如上一节所说:forword只有一次请求,而redirect有两次请求。

    重定向,其实是两次request:第一次,客户端 request A;服务器响应,并response回来,告诉浏览
    器,你应该去B。第二次,客户端 request B;服务器响应,返回数据。这个时候IE可以看到地址变了,而且历史的回退按钮也亮了。重定向可以访问自己web应用以外的资源。在重定向的过程中,传输的信息会被丢失。

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

再举一个简单的例子:
假设你去办理某个执照:

  • 重定向:你先去了A局,A局的人说:“这个事情不归我们管,去B局”然后你就从A退了出来,自己乘车去了B局。
  • 转发:你先去了A局,A局看了以后,知道这个事情其实应该B局来管,但是他没有把你退回来,而是让你坐一会儿,
    自己到后面办公室联系了B的人,让他们办好后,送了过来。

转发的时候你并不知道A局有没有去联系B局,信息有没有被泄露,有没有丢失。