好吧,有两种选择:
您必须指定正则表达式而不是文字字符串,并且该正则表达式必须匹配所有异常。
你使用重写地图。我建议你看一下文档。
使用正则表达式:
# some expections
RewriteCond %{HTTPS} =off [NC]
RewriteCond %{REQUEST_URI} ^/(example[0-9]+.*)$ [NC]
RewriteRule ^(.*)$ https://example.com/%1 [R=301,L]
# the default rule: => add "www."
RewriteCond %{HTTP_HOST} !^www.example.com$ [NC]
RewriteRule ^(.*)$ http://www.example.com/$1 [L,R=301]
我扭转了局面,在开始时有异常,最后是“全部捕获”默认值。显然,您可以通过将第一行加倍来添加更多例外。或者通过更改正则表达式。请注意,显然所需的正则表达式的详细信息取决于您拥有的异常集合。只有你知道......我建议你阅读优秀的手册。
除了更复杂的正则表达式,您还可以在条件块内使用逻辑运算符:
# some expections
RewriteCond %{HTTPS} =off [NC]
RewriteCond %{REQUEST_URI} ^/(example1.*)$ [NC,OR]
RewriteCond %{REQUEST_URI} ^/(example2.*)$ [NC]
RewriteRule ^(.*)$ https://example.com/%1 [R=301,L]
# the default rule: => add "www."
RewriteCond %{HTTP_HOST} !^www.example.com$ [NC]
RewriteRule ^(.*)$ http://www.example.com/$1 [L,R=301]
在谈到重写时,有两件重要的事情不能经常重复:
阅读手册!它非常好,带有精确的描述和很好的例子。
如果您有权访问主服务器配置,则使用 REWRITE DEBUGGING:重写模块为此定义了两个RewriteLog
命令RewriteLogLevel
。配置一些日志文件和级别可能为 7。然后发出一个请求并监视日志文件中的新条目(使用tail -f /path/to/logfile
)。这有助于了解重写引擎内部发生了什么以及意外事情开始发生的地方。