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)


相关推荐

  • StretchBlt和StretchDIBits

    StretchBlt和StretchDIBitsStretchBlt:从源矩形中复制一个位图到目标矩形,必要时按目标设备设置的模式进行图像的拉伸或压缩,如果目标设备是窗口DC,则意味着在窗口绘制位图,大致的使用代码如下:1voidDrawImage(HDChdc,HBITMAPhbm,constRECTtarget_rect)2{3HDChdcMemory=::CreateCom…

  • 使用Babel将es6转换es5

    使用Babel将es6转换es5目录Babel是什么?命令行转换babel-cli安装使用配置文件babel-polyfill安装在js中使用将Babel集成到webpack中Babel配置webpack配置1)安装webpack2)添加配置文件webpack.config.js3)修改package.json4)打包 拓展npm中save与save-d…

  • 5种方式实现 Java 单例模式

    5种方式实现 Java 单例模式单例模式(SingletonPattern)是Java中最简单的设计模式之一。这种类型的设计模式属于创建型模式,它提供了一种创建对象的最佳方式。这种模式涉及到一个单一的类,该类负责创建自己的对象,同时确保只有单个对象被创建。这个类提供了一种访问其唯一的对象的方式,可以直接访问,不需要实例化该类的对象。是否多线程安全:是是否懒加载:否正如名字含义,饿汉需要直接创建实例。缺点:类加载就初始化,浪费内存优点:没有加锁,执行效率高。还是线程安全的实例。懒汉单例,在类初始化不会创建实例,只有被调用时

  • 安装pyodbc_编程python是什么

    安装pyodbc_编程python是什么1、连接数据库pipinstallpyodbc成功后就可以用了首先要importpyodbc1)直接连接数据库和创建一个游标(cursor)cnxn=pyodbc.connect(‘DRIVER={SQLServer};SERVER=localhost;DATABASE=testdb;UID=me;PWD=pass’)cursor=cnxn.cursor()2)使用DSN连接。通常DSN连接并不需要密码,还是需要提供一个PSW的关键字。cnxn=pyodb

  • kali激活成功教程软件_kali渗透教程

    kali激活成功教程软件_kali渗透教程转载请注明出处:https://blog.csdn.net/l1028386804/article/details/84895163VeilEvasion简介VeilEvasion是一个可执行文件,它被用来生成Metasploit的payload,能绕过常见杀软。免责声明:本教程目的只是为了教育,我们不对这些东西会如何使用担任何风险,使用它的后果自负。Veil-Evasion被…

  • windows 激活状况 命令查询

    windows 激活状况 命令查询slmgr-ipkKey安装产品密钥slmgr-upk卸载密钥slmgr-ato激活密钥sLUI4显示电话激活选项msinfo32查看电脑组件系统详细信息slmgr-skms激活服务器以下又是产品win8版本激活的显示状态:slmgr.vbs-dlv显示:最为详尽的激活信息,包括:激活ID、安装ID、激活截止日期slmgr.vbs-dli显示:…

发表回复

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

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