url重写与cloudflare SSL的冲突

时间:2017-07-01 05:52:55

标签: apache .htaccess mod-rewrite

RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-l
RewriteCond %{REQUEST_FILENAME} !-d
RewriteRule (?!^infos/)^(.+?)/?$ /dl.php?f=$1 [L,QSA,NC]

此规则在使用Cloudflare切换到https / SSL后停止工作,我无法理解为什么?

如果我在没有https://部分的情况下尝试完全相同的URL,则页面是可访问的,因此规则正在运行,但仅适用于非安全URL

1 个答案:

答案 0 :(得分:1)

请记住,从http服务器的角度来看,域的http和https变体由两个完全独立的主机提供服务。这意味着您有单独的配置。很可能ssl主机已启用动态配置文件(“.htaccess”)的解释。看看apache AllowOverride指令......

一般提示:您应该始终更喜欢将此类规则放在http服务器(虚拟)主机配置中,而不是使用动态配置文件(.htaccess样式文件)。这些文件非常容易出错,难以调试,它们确实会降低服务器的速度。它们仅作为最后一个选项提供给您无法控制主机配置的情况(阅读:非常便宜的托管服务提供商),或者您有一个依赖于编写自己的重写规则的应用程序(这是一个明显的安全噩梦) )。