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

转发与重定向

作者头像
LiosWong
发布2018-10-29 17:37:37
9270
发布2018-10-29 17:37:37
举报
文章被收录于专栏:后端沉思录后端沉思录

平常开发中时常用到重定向,正好借此总结一下,上面的图在开发中以及参考网上文章总结出来的(参考文章见文末)。

重定向

代码语言:javascript
复制
@RequestMapping(value = "/redirect",method = RequestMethod.GET)
@ResponseBody
public String redirect(HttpServletResponse response){
    try {
        response.sendRedirect("http://127.0.0.1:8080/api/redirect/test");
    } catch (IOException e) {
        e.printStackTrace();
    }
    return "redirect";
}
@RequestMapping(value = "/redirect/test",method = RequestMethod.GET)
@ResponseBody
public String redirectTest(HttpServletRequest request, HttpServletResponse response){
    return "redirect success";
}

项目启动成功后,在浏览器输入 http://127.0.0.1:8080/api/redirect,在chrome检查Network栏目下,可以看到:

客户端发生了两次接口请求,第一次是 http://127.0.0.1:8080/api/redirect,第二次是 http://127.0.0.1:8080/api/redirect/test;且第一次接口请求的响应状态码为302(重定向),从其请求、响应头中可以清晰交互流程:

从上面分析,重定向时,进行了两次接口请求;过程简单理解为浏览器首先请求接口A,接口A进行了重定向到B,接口A给浏览器的响应状态码为302,并且返回了目的接口地址B,然后浏览器再次发起请求,请求接口地址B.

转发

代码语言:javascript
复制
@RequestMapping(value = "/forward",method = RequestMethod.GET)
@ResponseBody
public String forward(HttpServletRequest request, HttpServletResponse response){
    try {
        request.getRequestDispatcher("/api/forward/test").forward(request,response);
    } catch (IOException e) {
        e.printStackTrace();
    } catch (ServletException e) {
        e.printStackTrace();
    }
    return "index";
}
@RequestMapping(value = "/forward/test",method = RequestMethod.GET)
@ResponseBody
public String forwardTest(HttpServletRequest request, HttpServletResponse response){
    return "forward success";
}

在浏览器中访问 http://localhost:8080/api/forward,会返回 forward success,在chrome检查Network栏目下:

浏览器只请求了一次接口,请求地址没有发生变化;而且只能转发给当前的WEB应用资源。

总结

  1. 重定向是客户端行为,转发是服务器行为
  2. 转发只发生一次请求;且只能转发到当前应用资源;请求地址不会发生变化
  3. 重定向发生两次请求;且能重定向到任何资源;地址栏会发生变化
  4. 转发速度快于重定向

参考文章

  1. https://blog.csdn.net/daochuwenziyao/article/details/54233496
  2. https://blog.csdn.net/webzhuce/article/details/54564608
本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2018-10-07,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 后端沉思录 微信公众号,前往查看

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

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

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