平常開發中時常用到重定向,正好藉此總結一下,上面的圖在開發中以及參考網上文章總結出來的(參考文章見文末)。
重定向
@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.
轉發
@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應用資源。
總結
- 重定向是客戶端行爲,轉發是服務器行爲
- 轉發只發生一次請求;且只能轉發到當前應用資源;請求地址不會發生變化
- 重定向發生兩次請求;且能重定向到任何資源;地址欄會發生變化
- 轉發速度快於重定向
參考文章
- https://blog.csdn.net/daochuwenziyao/article/details/54233496
- https://blog.csdn.net/webzhuce/article/details/54564608