我想删除在我们的网站上使用的一些网址的所有结尾。由于某些原因,许多URL被索引,即使它们被robot.txt阻止
刚刚检查了谷歌搜索控制台今天“索引,虽然被robots.txt屏蔽”- 1,200+ URL
它们的形式都是一样的
https://www.ifootpath.com/display-ifootpath-walk?walkID=11470&username
他们应该是
https://www.ifootpath.com/display-ifootpath-walk?walkID=11470
每个URL (步行指南)的结束编号都会改变,所以我想我只是想删除'&username‘
谢谢
发布于 2018-09-08 16:27:34
正如已经在问题的注释中提到的,这里需要两个步骤:
RewriteEngine on
RewriteCond %{QUERY_STRING} ^walkID=(\d+)&
RewriteRule ^/?display-ifootpath-walk$ /display-ifootpath-walk/%1 [R=301]
RewriteRule ^/?display-ifootpath-walk/(\d+)$ /display-ifootpath-walk?walkID=$1 [END]该规则集将在http服务器主机配置和该主机的DOCUMENT_ROOT内的动态配置文件(".htaccess“样式文件)中类似地工作。
请注意,我没有测试这些行,而是只写下了我认为合适的行。但我真的希望我没有犯任何愚蠢的打字错误或逻辑错误...
如果您收到带有这些规则的http状态500 (“内部服务器错误”),那么很可能您操作的是apache http服务器的一个非常旧的版本。在这种情况下,尝试用[L]替换[END]标志。
还有一个一般性的注意事项:您应该始终倾向于将这样的规则放在http服务器主机配置中,而不是使用动态配置文件(".htaccess")。这些动态配置文件增加了复杂性,通常是导致意外行为的原因,难以调试,并且它们确实减慢了http服务器的速度。它们仅在您无法访问真实的http服务器主机配置(读作:真正便宜的服务提供商)或坚持编写自己的规则的应用程序(这是一个明显的安全噩梦)的情况下才被提供作为最后的选择。
https://stackoverflow.com/questions/52217635
复制相似问题