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:低
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:低
相关文章推荐
- 【前端学习】javascript正则表达式和字符串RegExp and String(一)
- 用Servlet处理表单提交的数据,然后再jsp页面中显示
- JavaScript 通过ClassName获取元素
- JavaScript 控制元素隐藏显示
- JS获得鼠标位置(已经解决不同浏览器问题)
- JS如何判断包括IE11在内的IE浏览器
- 妙味js视频学习之旅(二)
- Jasmine: JavaScript 单元测试框架
- 对json进行封装
- jsp与servlet的联系
- javascript实现动态添加内容与删除内容
- C# webbrowser中json后缀的文件不能显示的问题
- JSP中图片路径包含中文的问题
- js的调用函数前先执行某语句问题
- javascript实现全选与反选
- 网页链接说明的JS程序
- js跳转页面并传值以及localStorage的用法
- JSTL标签
- Ajax Post 传输对象或数组的解决方案
- js图片转base64并压缩