大家好,又见面了,我是你们的朋友全栈君。
一、转发
转发的原理,可以通过下图展示:
浏览器的请求发送给组件1, 组件1经过一些处理之后, 将request和response对象“传递”给组件2,由组件2继续处理, 然后输出响应(当然,也可以继续向其他组件“传递”), 这个传递的过程称之为“转发”。整个过程只涉及一次浏览器和服务器之间的“请求-响应”,转发过程中的组件共享同一个请求(request)和响应(response)对象。 转发的意义在于可以实现组件的**“分工”。**在基于MVC,多层结构的Web应用中,经常需要多个组件协同完成一次“请求-响应”工作,
RequestDispatcher对象封装了转发操作。 通过request的getRequestDispatcher(Stringpath)方法获得RequestDispatcher对象, 其中String类型参数path表示要转发到的地址。 调用Dispacther对象的forward(request, response)方法实现转发。 关于转发的具体操作,有如下几点需要注意:
1、转发只能在同一个应用的组件之间进行,不可以转发给其他应用的地址。 2、转发的地址可以用“相对地址”方式,也可以用“绝对地址”方式。但需要注意的是:用绝对地址方式时,应从应用名后(Context path)开始。例如:要转发到的地址为:http://192.168.5.100/tst/jsp/somewhere.jsp (其中tst为应用名), 对应的绝对地址为:“/jsp/somewhere.jsp”。 这是很好理解的**,因为转发只能转到本应用内的地址, 所以绝对地址是没有必要包含应用名的。** 3、组件之间通过转发来分工协作,势必涉及数据的传递, 可以通过request对象传递数据。 request对象的setAttribute和getAttribute分别用于以“名称-对象对”的形式存取数据。例如:
request.setAttribute("food","roast duck");
RequestDispatcher rd =request.getRequestDispatcher("jsp/somewhere.jsp");
rd.forward(request, response);
//somewhere.jsp的内容:
<h1>Hey,<%=request.getAttribute("food")%></h1>
在转发之前通过request的setAttribute(Stringname,Object obj)方法 向request中存入了一个名为“food”的字符串对象“roast duck”。
在转发到的jsp/somewhere.jsp中可以通过request的方法 getAttribute方法取出名为“food”的对象,然后显示在页面上
4、在一个组件转发给另外一个组件之前, 通过response输出的响应内容是没有意义的。 例如:在下面的语句中:
response.setContentType("text/html");
PrintWriter out = response.getWriter();
out.println("<h2>head</h2><hr/>");
RequestDispatcher rd =request.getRequestDispatcher("jsp/somewhere.jsp");
rd.forward(request, response);
用户看到的是/jsp/somewhere.jsp的内容,而在转发之前的通过out对象输出的内容:
“
“最终不会输出到浏览器,这是由于RequestDispatcher在转发之前清空了输出缓冲区。但如果在转发之前输出的信息超出了缓冲区,或者调用了out对象的flush()方法,此响应内容已经输出到了客户端(称之为响应信息已提交),此时如果实施转发操作会抛出运行时异常:java.lang.IllegalStateException。
二、重定向 重定向的含义可以由下图说明:
浏览器向某组件发出请求信息, 组件向浏览器发回一个重定向响应信息, 该响应信息不包含具体的数据内容, 只是在响应头信息中包含了需要重定向到的地址信息,该地址可以是任何有效的URL。
浏览器收到该重定向响应后会自动的向响应信息头中所指示的地址发出请求。 整个重定向的过程涉及**两次“请求-响应”。**具体的重定向响应格式如下所示:
HTTP/1.1 302 Moved Temporarily
Server: Apache-Coyote/1.1
Location:http://192.168.5.100:8080/tst/jsp/somewhere.jsp
Content-Length: 0
Date: Mon, 30 Jun 2008 03:52:54 GMT
注意:重定向响应中包含重定向地址的部分。
重定向可以通过response的sendRedirect(String url)方法来实现, 注意String类型的参数url表示重定向到的地址, 需要注意的是,如果表示重定向到本应用内的一个绝对地址时,要从应用名前开始, 例如:tst应用中的某个组件要重定向到本应用内的/jsp/somewhere.jsp, **则重定向的绝对地址应该是:“/tst/jsp/somewhere.jsp”**这一点和转发中的绝对地址(“jsp/somewhere.jsp”)表示是不同的。
转发是内部的,重定向是外部的 转发是服务器内部跳转,数据不会丢失,浏览器只提交了一次请求
重定向是客户端二次跳转,数据会丢失,浏览器提交了二次请求
做增、删、改的时候最好用重定向,因为如果不用重定向,每次刷新页面就相当于再请求一次,就可能会做额外的操作,导致数据不对。
如果你要跳转的那个页面需要用到你本页的参数, 就用转发request.getRequestDispache(“目标页面”).forward(request,response), 反之则可以用重定向
转发是在服务器内跳转的 重定向是服务器反馈客户端,由客户端重新发起其他请求
二、本质区别 解释一 一句话,转发是服务器行为,重定向是客户端行为。为什么这样说呢,这就要看两个动作的工作流程:
转发过程:客户浏览器发送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的人,让他们办好后,送了过来。
先搞清楚request和session的概念, request是一次请求, session通常是在由服务器设置的一段时间之内都会存在的。 到时间session会关闭。当然也可以手动关闭
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/195993.html原文链接:https://javaforall.cn