您的位置:首页 > Web前端 > JavaScript

JSP中forward和redirect的区别

2015-09-29 20:26 423 查看
在JSP中页面跳转有2中方式

1、forward :request.getRequestDispatcher("/somePage.jsp").forward(request, response);

2、redirect :response.sendRedirect("/somePage.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的人,让他们办好后,送了过来。

总结:

1.从地址显示来说

forward是服务器请求资源,比如你转向的地址为2.jsp,这时服务器先自己直接访问2.jsp,把这个地址的内容读出来,然后把这些内容再发给浏览器。所以地址栏还是你访问servlet那个地址栏(如果你用jsp实现地址就不变),它不会变成2.jsp。浏览器不知道这些内容是服务器从地址2.jsp拿过来的。

redirect则相反,是服务端根据逻辑,发送一个状态码高速浏览器重新去请求那个2.jsp地址,所以地址栏显示的是新的URL。所以redirect等于客户端向服务器端发出两次request,同时也接受两次response

2.从数据共享来说

forward转发页面和转发到的页面可以共享request里面的内容;redirect不能共享数据。

3.从运用地方来说

forward一般用于用户登录时候,根据角色转发到相应的模块(因为这时可能需要共享些数据)。

redirect一般用于用户注销登录时返回主页面和跳转到其他的网站。

4.forward不能跨域访问,redirect可以跨域访问

可能有些读者还不清楚跨域访问的概念。跨域访问就是post/get不是你自己的网站、域名不同的访问。

5.从协议的角度来说

forward的实现与协议无关。从原理上看,forward是container内部在response之前对request的处理。

而redirect方式是利用http协议中的redirect机制让客户发起新的请求,转向新的url。

从这个角度去看两者的区别,自然能很好地解析产生上面四点的不同的原因了。

所以,在处理登录/注销页面的转向时,要注意forward与redirect所带来的不同效果

6.从效率来说

forward:高.

redirect:低
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: