response.sendRedirect()与request.getRequestDispatcher().forward()区别

response.sendRedirect()与request.getRequestDispatcher().forward()区别Servlet中response.sendRedirect()与request.getRequestDispatcher().forward(request,response)这两个对象都可以使页面跳

大家好,又见面了,我是你们的朋友全栈君。

Servlet中response.sendRedirect()与request.getRequestDispatcher().forward(request,response)这两个对象都可以使页面跳转,但是二者是有很大的区别的,分条来说,有以下几点:

①response.sendRedirect(url)—–重定向到指定URL (经过一次重定向后,request内的对象将无法使用,request中存放的变量全部失效)

  request.getRequestDispatcher(url).forward(request,response) —–请求转发到指定URL

补充说明:getRequestDispatcher分成两种,可以用request调用,也可以用getServletContext()调用 ,不同的是request.getRequestDispatcher(url)的url可以是相对路径也可以是绝对路径;而this.getServletContext().getRequestDispatcher(url)的url只能是绝对路径。

②response.sendRedirect(url)—–是客户端跳转(浏览器中所显示的URL会变成新页面的URL)

  request.getRequestDispatcher(url).forward(request,response) —–是服务器端跳转(URL会保持不变)

③response.sendRedirect(url)跳转到指定的URL地址后,上个页面(跳转之前的原来页面)中的请求全部结束,原request对象将会消亡,数据将会消失。紧接着,当前新页面会新建request对象,即产生新的request对象。

详细过程:redirect 会首先发一个response给浏览器,然后浏览器收到这个response后再发一个requeset给服务器,服务器接收后发新的response给浏览器。这时页面从浏览器获取来的是一个新的request。这时,在原来跳转之前的页面用request.setAttribute存的东西都没了,如果在当前的新页面中用request.getAttribute取,得到的将会是null。

 request.getRequestDispatcher(url).forward(request,response)是采用请求转发方式,在跳转页面的时候是带着原来页面的request和response跳转的,request对象始终存在,不会重新创建。

详细过程:forward 发生在服务器内部, 是在浏览器完全不知情的情况下发给了浏览器另外一个页面的response. 这时页面收到的request不是从浏览器直接发来的,可能是在转页时己经用request.setAttribute在request里放了数据,在转到的页面就可以直接用request.getAttribute获得数据了。

④使用response.sendRedirect()地址栏中的网址将改变

  使用request.getRequestDispatcher().forward(request,response)地址栏中的网址保持不变。

⑤使用response.sendRedirect()时如果需要传递参数,那只能在url后加参数,如:url?id=1,而不能通过request或response方式。

  使用request.getRequestDispatcher().forward(request,response)如果需要传递参数,可以在程序内通过response.setAttribute(“name”,name)来传至下一个页面.而不能在后面带参数传递,比如servlet?name=frank这样不行。

⑥运用sendRedirect()方法可以让你重定向到任何URL,而forward()方法只能重定向到同一个Web应用程序中的某个资源。

  表单form中的action=”/uu”;sendRedirect(“/uu”);表示相对于服务器根路径。如服务器根路径是http://localhost:8080/Test则提交至http://localhost:8080/uu;而Forward代码中的”/uu”则代表相对于WEB应用的路径。如http://localhost:8080/Test应用则提交至http://localhost:8080/Test/uu。

运用HttpServletResponse接口的sendRedirect()方法

 sendRedirect()是在用户的浏览器端工作,同时它可以重定向至不同的主机上,sendRedirect()可以重定向有frame的jsp文件

假设转发代码包含于注册的servlet-url为/ggg/tt;jsp为/ggg/tt.jsp。

绝对路径:response.sendRedirect(“http://www.brainysoftware.com”)发送至http://www.brainysoftware.com
根路径:response.sendRedirect(“/ooo”)发送至
http://localhost:8080/ooo
相对路径:response.sendRedirect(“ooo”)发送至http://localhost:8080/Test/ggg/ooo

 sendRedirect等同于此方式:

response.setStatus(HttpServletResponse.SC_MOVED_PERMANENTLY);

String newLocn = “/newpath/jsa.jsp”;

response.setHeader(“Location”,newLocn);

运用RequestDispatcher接口的Forward()方法 

  forward()无法重定向至有frame的jsp文件,可以重定向至有frame的html文件,

只有在客户端没有输出时才可以调用forward方法。如果当前页面的缓冲区(buffer)不是空的,那么你在调用forward方法前必须先清空缓冲区。

“/”代表相对与web应用路径 

RequestDispatcher rd = request.getRequestDispatcher(“/ooo”);

rd.forward(request, response);提交至http://localhost:8080/Test/ooo

 

RequestDispatcher rd = getServletContext().getRequestDispatcher(“/ooo”);

rd.forward(request, response);提交至http://localhost:8080/Test/ooo

 

RequestDispatcher rd =getServletContext().getNamedDispatcher(“TestServlet”);(TestServlet为一个<servlet-name>)

rd.forward(request, response);提交至名为TestServlet的servlet

 

如果在<jsp:forward>之前有很多输出,前面的输出已使缓冲区满,将自动输出到客户端,那么该语句将不起作用,这一点应该特别注意。

另外要注意:它不能改变浏览器地址,刷新的话会导致重复提交。

http://localhost:8080/Test/gw/page.jsp中转发

<jsp:forward page=”OtherPage.jsp”/>在JSP页面被解析后转换成pageContext.forward(“OtherPage.jsp”);

“/OtherPage.jsp”提交到http://localhost:8080/Test/OtherPage.jsp

“OtherPage.jsp”提交到http://localhost:8080/Test/gw/OtherPage.jsp

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/155330.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • 初识不知曲中意,再听已是曲中人下一句是什么_调用action方法出错

    初识不知曲中意,再听已是曲中人下一句是什么_调用action方法出错动作类是多例的,每次动作访问,动作类都会实例化。所以是线程安全的。在每次动作执行前,核心控制器StrutsPrepareAndExecuteFilter都会创建一个ActionContext和ValueStack对象。且每次动作访问都会创建。这两个对象存储了整个动作访问期间用到的数据。并且把数据绑定到了线程局部变量(ThreadLocal)上了。所以是线程安全的。contextMap使用struts内置标签<s:debug>查看contextMap数据利用ActionCo.

  • 【mysql】索引优化

    【mysql】索引优化【mysql】索引优化

  • C语言刷屏

    C语言刷屏QQ刷屏原理和复制粘贴差不多,只不过是叫系统帮你粘贴并摁下回车键。#include<stdio.h>#include<Windows.h>intmain(){ intn; charname[100]; printf(“请输入窗口名字:”); scanf(“%s”,&name);//窗口名字 printf(“请输入刷屏次数:”);…

  • 只需十四步:从零开始掌握 Python 机器学习(附资源)[通俗易懂]

    只需十四步:从零开始掌握 Python 机器学习(附资源)[通俗易懂]分享一篇来自机器之心的文章。关于机器学习的起步,讲的还是很清楚的。原文链接在:只需十四步:从零开始掌握Python机器学习(附资源)「开始」往往是最难的,尤其是当选择太多的时候,一个人往往很难下定决

  • sqlyog13.1.6激活成功教程版_sqlyog10.0安装教程

    sqlyog13.1.6激活成功教程版_sqlyog10.0安装教程1、SQLyog-12.2.4-0.x64Trial.exe,直接去官网下载。2、修改注册表项开始-运行-regedit,进入注册表HKEY_CURRENT_USER\Software\SQLyog修改权限拒绝修改。OK,激活成功教程完成。试用14天一直可以使用下去转载于:https://www.cnblogs…

  • JS基础——cssText的用法[通俗易懂]

    JS基础——cssText的用法[通俗易懂]JS基础——cssText的用法#div1{width:100px;height:100px;background:#f3f3f3;border:1pxsolid#ccc;color:red;}window.onload=function(){ var oDiv=document.getElementById(‘div1’); varoBtn=docume

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号