我意识到这类问题已经有很多,但是我认为我的情况是独特的。我想使用.htaccess强制所有内容都使用HTTPS,但对于一个名为pirate的目录,它是可选的。我以前做过类似的事情,但这次没有成功。首先,我尝试了以下代码,成功地强制所有内容使用HTTPS。
<IfModule mod_rewrite.c>
RewriteEngine On
RewriteBase /
RewriteCond %{SERVER_PORT} 80
RewriteRule ^(.*)$ https://%{SERVER_NAME}%{REQUEST_URI} [L,R=301]
RewriteCond $1 !^(blog|images|css|js|robots\.txt|favicon\.ico)
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
RewriteRule ^(.*)$ /index.php?/$1 [L]
</IfModule>
<IfModule !mod_rewrite.c>
ErrorDocument 404 /index.php
</IfModule>
然后我添加了异常处理(这里只展示第一个规则):
RewriteCond %{SERVER_PORT} 80
RewriteCond %{REQUEST_URI} !^(/pirate/) [NC]
RewriteRule ^(.*)$ https://%{SERVER_NAME}%{REQUEST_URI} [L,R=301]
搞定啦!所有控制器都应该使用HTTPS:
1) http://www.mysite.com/contact/ -> https://www.mysite.com/contact
检查一下。我的海盗控制器也应该能够处理HTTPS:
2) https://www.mysite.com/pirate/ -> https://www.mysite.com/pirate/
没有变化。完美!最后,海盗控制器应该能够使用传统的HTTP协议:
3) http://www.mysite.com/pirate/ -> https://www.mysite.com/index.php?/pirate/
这不对。它仍然强制使用HTTPS,并停止隐藏index.php。因此,总结一下,我有两个条件和一个规则。如果第一个条件为真且第二个条件为假,则应用规则,然后应用第二个规则,然后返回301重定向。我知道这听起来很奇怪,但如果不是这样,我就不会问了。
为什么会发生这种情况,我该如何解决?