前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >spring转发和重定向

spring转发和重定向

作者头像
用户9184480
发布2024-12-17 11:10:56
发布2024-12-17 11:10:56
12600
代码可运行
举报
文章被收录于专栏:云计算linux云计算linux
运行总次数:0
代码可运行
代码语言:javascript
代码运行次数:0
运行
复制
<div><!-- 登陆页面-->
        <form action="demo/login" method="post">
        账户:<input type="text" name="username"/><br/>
        密码:<input type="password" name="pwd"/><br/>
        <input type="submit" value="登录"/>
        </form>
    </div>
    <form action="demo/login" method="post">
        账户:<input type="text" name="username"/><br/>
        密码:<input type="password" name="pwd"/><br/>
        <input type="submit" value="登录"/>
        </form>
    </div>

代码语言:javascript
代码运行次数:0
运行
复制
对于控制器内的方法间的调用,有转发和重定向两种。
代码语言:javascript
代码运行次数:0
运行
复制
@RequestMapping("/login")
  public String login(Userinfo u,HttpSession s){
    System.out.println("login:"+u.getUsername()+","+u.getPwd());
    s.setAttribute("u",u);//放到session里面;

    return "redirect:list";//相当于从客户端再次发送请求
    //return "forward:list";//转发,是服务器页面转了一下
  }
  @RequestMapping("/list")
  public String list(Userinfo u,HttpSession s){
    System.out.println(s.getAttribute("u"));
    return "list";//返回页面
  }

转发对于数据Userinfo来说,可以在list页面显示出来,从登陆页面到list页面,而如果是重定向,则不能有数据的传递。

<body>

我是重定向、或转发过来的页面.{u.username },{u.pwd }

</body>

请求重定向与请求转发的比较,HttpServletResponse.sendRedirect方法和RequestDispatcher.forward方法都可以让浏览器获得另外一个URL所指向的资源,但两者的内部运行机制有很大的区别。

1.RequestDispatcher.forward方法只能将请求转发给同一个Web应用中的组件,HttpServletResponse.sendRedirect不仅可以重定向到当前应用程序的其他资源,还可以重定向到同一个站点上的其他应用程序的资源,甚至是使用绝对URL重定向到其他站点的资源。对于sendRedirect如果传递的URL以”/”开头,他是相对于整个Web站点的根目录;对于forward如果传递的URL以”/”开头,它是相对于当前Web应用程序的根目录。

2.sendRedirect对浏览器做出的响应是重新发出对另外一个URL的访问请求,forward在服务器端内部将请求转发给另外一个资源,浏览器只知道发出了请求并得到了响应结果

3.forward的调用者与被调用者之间共享相同的request对象和response对象,他们属于同一个访问请求和响应过程;sendRedirect的调用者与被调用者使用各自的request和response对象,属于两个独立的访问请求和响应过程

请求重定向以redirect:开头,请求转发以forward:开头;

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-03-10,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档