请求转发与重定向的概念
- 请求转发是服务器端跳转,它只产生一次请求,客户端请求到达服务器之后中会发生一次转发,之后服务器才将结果发送到客户端
- 重定向是客户端跳转,它会产生两次请求,首先发一个response到浏览器,浏览器收到这个response后再发一个requeset到服务器,服务器接收后发新的response给浏览器
- 当使用重定向时,浏览器中所显示的URL会变成新资源的URL。因为浏览器还得发出一个新的请求,所以重定向的速度比转发慢。同时,由于重定向方式产生了一个新的请求,所以经过一次重定向后,原request内的信息将无法使用
图示说明
请求转发与重定向的区别
- 转发时客户端浏览器请求一次服务器;而重定向需要客户端请求两次服务器
- 重定向时不管第一次请求时的方式是什么,第二次请求时方式都是GET;而转发时,两次的方式是一样的
- 当请求templates目录中的资源时,只能使用请求转发而不能使用重定向
- 重定向是无法传递数据的,要想传内容或者参数只能在url路径后面添加参数例如:url地址?参数名称=参数值;
response.sendRedirect(“url地址?参数名称=参数值”) - 请求转发结束后,浏览器地址栏保持初始的URL地址不变;而调用重定向访问过程结束后,浏览器地址栏中显示的URL会发生改变,由初始的URL地址变成重定向到的目标URL
- 请求转发的整个请求跳转过程是在服务器端实现的,客户端并不知道,即:请求转发在服务器端将请求转发给另外一个资源,浏览器只知道发出了请求并得到了响应结果,并不知道在服务器程序内部发生了转发行为;而重定向是对浏览器的请求直接做出响应,响应的结果就是告诉浏览器去重新发出对另外一个URL的访问请求
- RequestDispatcher.forward()方法的调用者与被调用者之间共享request对象和response对象,它们属于同一个请求和响应的过程;而HttpServletResponse.sendRedirect()方法调用者与被调用者使用各自的request对象和response对象,它们属于两个独立的请求和响应的过程
- RequestDispatcher.forward()只能将请求转发给同一个WEB应用中的其它资源;而HttpServletResponse.sendRedirect()还可以重定向到同一个站点上的其他应用程序中的资源,甚至是使用绝对URL重定向到其他站点的资源
- 转发地址栏不变,重定向地址改变
- 转发可以携带request对象到目标资源,重定向未携带request对象
- 转发浏览器发送一次,重定向浏览器发送两次请求
- 转发可以访问当前服务下的资源,重定向不能直接访问当前服务下的资源
重定向的实现方式
-
方式一,返回redirect
使用场景:在返回视图的前面加上
redirect
的方式,更加适用于项目内视图的跳转,从一个网页跳转到另一个网页//不能在接口上添加@ResponseBody注解 @GetMapping(path = "r1") public String r1() { return "redirect:/redirect/index?base=r1"; }
-
方式二,HttpServletResponse重定向
使用场景:除从一个网页跳转到另一个网页之外的场景
@ResponseBody @GetMapping(path = "index") public void r2(HttpServletResponse response) throws IOException { response.sendRedirect("/redirectIndex");//也可以是域名 }
-
方式三,使用ModelAndView对象,与redirect类似,适用于项目内视图的跳转
public ModelAndView toRedirect() { ModelAndView modelAndView = new ModelAndView("需要跳转的页面路径"); return modelAndView; }
-
方式四,Nginx重定向,是指在Nginx中,重定向是指通过修改URL地址,将客户端的请求重定向到另一个URL地址的过程,Nginx中实现重定向的方式有多种,比如使用rewrite模块、return指令等
这里记录下在server配置中添加return指令
#重定向 location /web { return 301 https://example.com; } #重定向 location /web/login { return 301 https://example.com; }
题外:301与302重定向区别
- 301永久重定向使得搜索引擎在抓取新内容的同时将旧的网址替换为重定向后的网址
- 302临时性定向使得搜索引擎会抓去新的内容却保留旧的网址
适用场景区别:
- **301:**域名切换、HTTP迁移到HTTPS
- **302:**未登录用户访问个人中心时重定向到登录页面、404页面提示后跳转到首页
PS:302与网址劫持
网址劫持和302重定向有什么关系呢?这个要从搜索引擎如何处理302重定向说起。
当从网址A做一个302重定向到网址B时,服务器隐含的意思是网址A可能会重新启用。正常情况,大部分搜索引擎应当去抓取302重定向之后的网址B。但是可能由于B网址相对于A网址过于复杂,这样搜索引擎就会觉得网址A对用户更加友好,因而在重定向之后任然显示旧的网址A,但是显示网址B的内容。这就是网址劫持。
在平常使用手机的过程当中,有时候会发现网页上会有浮动的窗口,或者访问的页面不是正常的页面,这就可能是运营商通过某种方式篡改了用户正常访问的页面。其中有一种方式就是通过返回302重定向让用户浏览器跳转到另外的网址。