我写了以下重写规则:
<IfModule mod_rewrite.c>
RewriteCond %{QUERY_STRING} rp=\/knowledgebase\/.*
RewriteRule ^\/customer\/index.php /knowledgebase/ [R=301,L]
RewriteRule ^\/customer\/knowledgebase\.php$ /knowledgebase/ [R=301,L,QSA]
</IfModule>
重定向 URL,例如
https://www.example.com/customer/index.php?rp=/knowledgebase/5/DataNumen-Excel-Repair
至https://www.example.com/knowledgebase/
并重定向 URL,例如
https://www.example.com/customer/knowledgebase.php
至https://www.example.com/knowledgebase/
但两者都不起作用。为什么?
更新
我尝试将 MrWhite 的代码从 /.htaccess 放到 /customer/.htaccess 并进行一些小的更改以采用更改,如下所示:
RewriteCond %{QUERY_STRING} rp=/knowledgebase/
RewriteRule ^index\.php$ https://www.example.com/knowledgebase/ [QSD,R=301,L,NC]
RewriteRule ^knowledgebase\.php$ https://www.example.com/knowledgebase/ [R=301,L,NC]
现在重定向有效。但是,它仅适用于以下情况:
https://www.example.com/customer/index.php?rp=/knowledgebase/9/DataNumen-PDF-Repair
但对于像这样的情况
https://www.example.com/customer/index.php?a=b&c=d&rp=/knowledgebase/9/DataNumen-PDF-Repair
不起作用。即使我在 RewriteCond 中将 ^rp= 更改为 rp。
在中,模式
.htaccess
匹配的 URL 路径(即。)不以斜杠开头,因此永远不会匹配。匹配的 URL 路径相对于包含文件的目录(减去斜杠前缀)。(与在服务器上下文中使用时不同,当匹配的 URL 路径是文档根相对 URL 路径时,以斜杠开头。)RewriteRule
^\/customer\/index.php
.htaccess
您还需要
QSD
第一条规则上的标志来丢弃原始请求中的查询字符串,否则按原样传递。次要点......在Apache正则表达式中不需要反斜杠转义斜杠,因为空格是参数分隔符,斜杠在正则表达式中没有特殊含义。
请尝试以下操作:
我将查询字符串锚定在条件中,以便它
rp=...
在查询字符串的开头匹配,如您的示例所示。.*
不需要正则表达式末尾的。QSA
第二条规则不需要该标志,因为默认情况下会传递查询字符串。QSA
仅当您需要将请求中的原始查询字符串与您在替换中附加的新查询字符串合并时才需要该标志。<IfModule>
包装器不是必需的,除非这些指令是可选的并且旨在用于 mod_rewrite 可能不可用的多个服务器上。在网站管理员堆栈上查看此问题:https ://webmasters.stackexchange.com/questions/112600/is-checking-for-mod-write-really-necessary您应该首先使用 302(临时)重定向进行测试,以避免潜在的缓存问题。
在这种情况下,您需要删除每个patterns
customer/
上的前缀,就像您在更新的问题中所做的那样。RewriteRule
如果
rp
URL 参数旨在匹配查询字符串中的任何位置,那么您应该将CondPattern更改为 read(^|&)rp=/knowledgebase/
,而不是简单地删除^
前缀。通过删除^
前缀,您可能匹配太多,例如。abcrp=/knowledgebase/...
也会匹配,尽管这在现实中可能是也可能不是问题。否则,这些更新的指令看起来没问题,这取决于可能与其他指令存在的任何其他冲突。缓存也可能是一个问题,尤其是在您使用 CDN 时。