轉發與重定向

平常開發中時常用到重定向,正好藉此總結一下,上面的圖在開發中以及參考網上文章總結出來的(參考文章見文末)。

重定向

@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應用資源。

總結

  1. 重定向是客戶端行爲,轉發是服務器行爲
  2. 轉發只發生一次請求;且只能轉發到當前應用資源;請求地址不會發生變化
  3. 重定向發生兩次請求;且能重定向到任何資源;地址欄會發生變化
  4. 轉發速度快於重定向

參考文章

  1. https://blog.csdn.net/daochuwenziyao/article/details/54233496
  2. https://blog.csdn.net/webzhuce/article/details/54564608
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章