主动跳转:跳转动作是由浏览器的使用者主动发起的;
被动跳转:跳转动作是由服务器发起的,浏览器使用者无法控制。
1、重定向状态码
301:俗称“永久重定向”,原URI已经“永久”性地不存在了,今后的所有请求都必须改用新的URI.
302: 俗称“临时重定向”,原URI处于“临时维护”状态,新的URI是起“顶包”作用的临时工。
303 See Other: 类似302,但要求重定向后的请求改为GET方法,访问一个结果页面,避免POST/PUT重复操作;
307 Temporary Redirect: 类似302,但重定向后请求里的方法和实体不允许变动,含义比302更明确;
308 Permanent Redirect: 类似307,不允许重定向后的请求变动,但它是301“永久重定向”的含义
2、重定向的应用场景
一个最常见的原因就是“资源不可用”,需要用另一个新的URI来代替。
不可用的原因:如域名变更、服务器变更、网站改版、系统维护。
另一个原因就是“避免重复”,让多个网址都跳转到一个URI,增加访问入口的同时还不会增加额外的工作量。如:有的网站会申请多个名称类似的域名,然后把它们重定向到主站上。
3、重定向的相关问题
第一个问题是“性能损耗”。重定向的机制决定了一个跳转会有两次请求-应答,比正常的访问多了一次。
第二个问题是“循环跳转”。如果重定向的策略设置欠考虑,可能会出现“A=>B=>C=>A”的无限循环。
1、重定向是服务器发起的跳转,要求客户端改用新的 URI 重新发送请求,通常会自动进行,用户是无感知的;
2、301/302 是最常用的重定向状态码,分别是“永久重定向”和“临时重定向”;301用于废弃原地址跳转新地址,302用于暂时无法访问原地址跳转新地址,两者都需要浏览器重新发起一次请求
3、响应头字段 Location 指示了要跳转的 URI,可以用绝对或相对的形式;
4、重定向可以把一个 URI 指向另一个 URI,也可以把多个 URI 指向同一个 URI,用途很多;
5、使用重定向时需要当心性能损耗,还要避免出现循环跳转。
补充
01 网页的“入链接”和“出链接”也是标记网页重要性的关键指标,最著名的就是Google发明的PageRank。
02“300 Multiple Choices"也是一个特殊的重定向状态码,它会返回一个有多个链接选项的页面,由用户自行选择要跳转的链接,用的较少。
03重定向报文 里还可以用Refresh字段,实现延时重定向,例如“Refresh: 5; url=xxx”告诉浏览器5秒钟后再跳转。
04与跳转有关的还有一个“Referer”和“Referrer- Policy”(注意前者是个拼写错误,但已经“将错就错”),表示浏览器跳转的来源(即弓|用地址),可用于统计分析和防盗链。
05 301/302 重定向是由浏览器执行的,对于服务器来说可以称为“外部重定向”相应的也就有服务器的“内部重定向”,直接在服务器内部跳转URI,因为不会发出HTTP 请求,所以没有额外的性能损失。
外部重定向,服务器会把重定向的地址给浏览器,然后浏览器再次的发起请求,地址栏的地址变化了。
内部重定向,服务器会直接把重定向的资源返给浏览器,不需要再次在浏览器发起请求,地址栏的地址不变。
重定向我的经验,主要用在未登录或者权限不足的场景,跳转到对应的登录或提升页面之中
301,302, 303重定向不要求前后协议一致,http可以调转https
重定向可以应用于实现负载均衡,但多了一次请求的成本,比较重
302不改变原uri,所以每次都会找原uri,成本较高,应当尽量少用