zoukankan      html  css  js  c++  java
  • response.sendRedirect()与request.getRequestDispatcher().forward()区别

    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

  • 相关阅读:
    教你如何有效防止DDos攻击?
    IsNumeric 判断字符串是否为数字(使用Val函数实现),这个函数相当于Java的IsNaN函数
    Delphi全角转半角
    SetLocalTime API函数设置本地时间(DateTimeToSystemTime函数,把TDateTime转换成TSystemTime)
    StyleBook皮肤控件的使用
    Qt 学习之路 2(19):事件的接受与忽略(当重写事件回调函数时,时刻注意是否需要通过调用父类的同名函数来确保原有实现仍能进行!有好几个例子。为什么要这么做?而不是自己去手动调用这两个函数呢?因为我们无法确认父类中的这个处理函数有没有额外的操作)
    C# 8.0、.NET Framework 4.8与NET Standard 2.1的一个说明
    基于PaaS和SaaS研发平台体系
    Redis 当成数据库在使用和可靠的分布式锁,Redlock 真的可行么?
    NET Core + Ocelot + IdentityServer4 + Consul
  • 原文地址:https://www.cnblogs.com/handsomeye/p/5145760.html
Copyright © 2011-2022 走看看