您现在的位置是:首页 > 技术文章

阿里云开启CDN HTTPS重定向的次数过多如何解决?

博主:紫藤心-迷途    日期:2020-07-03 浏览次数:528次

用户配置了阿里云CDN或者全站加速后,使用浏览器进行访问,出现重定向的次数过多的错误。

问题描述

配置了阿里云CDN或者全站加速后,使用浏览器进行访问,出现如下错误提示。

XXX.XXX.XXX 将您重定向的次数过多。
尝试清除 Cookie.
ERR_TOO_MANY_REDIRECTS

fda8a0b4bfd945d1863d41818ce58002.png

问题原因

源站开启了HTTP重定向至HTTPS的功能,并且CDN控制台上配置的回源端口为80。在这种情况下,由于CDN回源端口为80,客户端无论是通过HTTP还是HTTPS访问CDN加速域名时,CDN在回源的时候都是使用HTTP请求源站,此时会触发源站的HTTPS强制跳转逻辑,然后源站会要求CDN重新发送一个HTTPS的请求,但是CDN回源的时候仍然会发送HTTP回源请求,然后再进行跳转,以此类推,就会出现反复重定向问题,最终导致出现报错。

解决方法

本文介绍如下三种解决方法,请根据实际情况选择具体的方法。
方法一
登录CDN控制台,在域名管理页面单击目标域名对应的管理,然后单击 修改配置,将CDN的回源端口设置为443,并单击 确定。设置为443端口以后,CDN回源时会以HTTPS协议请求源站,就不会触发源站的强制跳转逻辑。

cbb4f0fc09b04b90b3e8744d33ec796e.png

方法二
将协议跟随回源设置为“跟随”。设置为跟随以后,源站发起HTTPS重定向以后,CDN回源协议跟随为HTTPS回源。

方法三
如果不希望将CDN的回源端口改成443,仍希望CDN以HTTP协议回源,这种情况下可以考虑关闭源站的HTTP重定向至HTTPS的强制跳转功能。

特别注意

如果按照上述建议修改配置以后问题还未解决,则可能是301被CDN节点缓存了,需要刷新下CDN的缓存,具体请参考刷新缓存操作。下面是一个异常现象的案例,访问HTTPS的URL以后,301重定向Location到同样的HTTPS地址,从Response Headers里可以看到301被CDN HIT缓存住了。

d26eead83b3d463d873c12f8b5094ef4.png

更多信息

由于使用了CDN,且客户端的请求都是先请求到CDN节点。如果希望CDN节点获取客户端的请求是HTTPS协议时,可以在CDN控制台上设置HTTP强制跳转,具体信息请参考配置强制跳转。

适用于

CDN
全站加速


分享到: / / / /
  • 点击此处扫一扫二维码,直接手机访问此页