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
答案 0 :(得分:1)
请记住,从http服务器的角度来看,域的http和https变体由两个完全独立的主机提供服务。这意味着您有单独的配置。很可能ssl主机不已启用动态配置文件(“.htaccess”)的解释。看看apache AllowOverride
指令......
一般提示:您应该始终更喜欢将此类规则放在http服务器(虚拟)主机配置中,而不是使用动态配置文件(.htaccess
样式文件)。这些文件非常容易出错,难以调试,它们确实会降低服务器的速度。它们仅作为最后一个选项提供给您无法控制主机配置的情况(阅读:非常便宜的托管服务提供商),或者您有一个依赖于编写自己的重写规则的应用程序(这是一个明显的安全噩梦) )。