重定向Redirect 的知识

服务器

浏览数:144

2019-7-23

AD:资源代下载服务

今天下班的时候看到了一些重定向的基础知识,也算开了眼界。以前也经常使用301和302,但从来没有使用过和了解过其他的3XX的状态码,发现原来里面涉及的知识和解决的问题的还不少。

重定向的流程

浏览器首先访问服务器A的URL,服务器A返回带着location为B的URL的 header 和3XX的状态码,浏览器读取响应的3XX状态码,获取到头部的 location,然后跳转到服务器B的URL。
需要知道的,跳转是浏览器发起的。如果服务器给一个非浏览器的终端返回了3XX的状态码,那有可能是无法完成重定向的。
某年,有个应该用已经运行很很长时间了,PHP写的API接口。一直使用的是HTTP,经常被劫持,然后领导想替换成加密的HTTPS,但是客户端不能发版。后来服务器端就考虑把全站的接口从HTTP 302到HTTPS,讨论这个方案的可行性。如果知道上面的流程和知识这个方案立马就PASS了。

永久重定向

表示资源永久性的跳转到新的URL。
一个比较常见的案例就是老站迁移到新站,老站直接关闭后,老站的页面已经被搜索引擎收录了,这个时候使用永久重定向方案。
永久重定向两个状态码
301,重定向请求通常会使用GET方法,不管原请求使用的是何种方法。
308,为了补充301.重定向必须使用原请求的方法和包体访问。

临时重定向

表示资源只是临时跳转到新的URL
临时重定向一共有五个状态码,常用也就相对应的两个302和307.
302,重定向请求通常会使用GET方法,不管原请求使用的是何种方法。
303,并不表示资源变更,只是表示用新的URL的响应代替原请求。不管原请求使用的是何种方法。基本跟302一致,所以市面很少用303,都是使用302.
307,为了补充302.重定向必须使用原请求的方法和包体访问。
百度就是使用的307跳转,浏览器输入http://www.baidu.com 会307 到https://www.baidu.com

300,该请求有多种可能的响应,浏览器可以选择它们其中的一个。服务器没有任何标准可以遵循去代替用户来进行选择。
304,告诉浏览器,所请求的内容距离上次访问并没有变化。 可以直接从浏览器缓存里获取该资源。
后面两种不常用。

使用比较多就是301 302 307 308

循环重定向的问题

ERR_TOO_MANY_REDIRECTS
这个报错挺常见的。如果访问A页面然后重定向访问B,然后B又让重定向访问A,这样就是循环重定向了。多次重定向也会报这个错。

生产环境遇到过一次,有一次日志上发现有ERR_TOO_MANY_REDIRECTS的报错,但是在Nginx的配置上没有找到 3XX的跳转代码啊,那怎么循环跳转的。后来看到了这段配置

    location / {
        try_files $uri $uri/ /index.html$is_args$args;
    }

后来发现根目录下没有index.html,uri不存在,然后uri/目录也不存在,最后发起一个内部子请求到index.html.index.html不存在,又到location,反复重定向。最后报错 ERR_TOO_MANY_REDIRECTS。

作者:飞翔码农