• java请求转发,响应重定向的区别


    请求转发:request.getRequestDispatcher().forward();   

    例:request.getRequestDispatcher("/index.jsp").forward(request,response);

    响应重定向:response.sendRedirect();           

     例:response.sendRedirect(request.getContextPath + "/index.jsp");

    请求转发过程
        客户首先发送一个请求到服务器端,服务器端发现匹配的servlet,并指定它去执行,当这个servlet执行完之后,它要调用getRequestDispacther()方法,把请求转发给指定的index.jsp,整个流程都是在服务器端完成的,

    而且是在同一个请求里面完成的,因此servlet和jsp共享的是同一个request,在servlet里面放的所有东西,在index中都能取出来,因此,index能把结果getAttribute()出来,getAttribute()出来后执行完把结果返回给客户端。

    整个过程是一个请求,一个响应。


    响应重定向过程
        客户发送一个请求到服务器,服务器匹配servlet,这都和请求转发一样,servlet处理完之后调用了sendRedirect()这个方法,这个方法是response的方法,所以,当这个servlet处理完之后,看到response.senRedirect()方法,立即向客户端返回这个响应,响应行告诉客户端你必须要再发送一个请求,去访问index.jsp,紧接着客户端受到这个请求后,立刻发出一个新的请求,去请求index.jsp,这里两个请求互不干扰,相互独立,在前面request里面setAttribute()的任何东西,在后面的request里面都获得不了。可见,在sendRedirect()里面是两个请求,两个响应。

    总结

      请求转发→一次请求→一次响应

      响应重定向→二次请求→二次响应

  • 相关阅读:
    js的解析顺序 作用域 严格模式
    弹性盒模型----容器属性
    tomcat解压版的配置与使用
    将mysql中一行中的几个字段 转换成一列并从其他数据库中查对应的邮件信息
    电脑快捷键
    icell更改用户管理员
    kettle下载地址
    pycharm激活码
    leetcode-111. 二叉树最小深度 · Tree + 递归
    leetcode-102.层序遍历二叉树(正序)· BTree
  • 原文地址:https://www.cnblogs.com/Yogurt-harry/p/11150105.html
Copyright © 2020-2023  润新知