У меня проблема с моим .htaccess
файл.
У Google есть проиндексированные URL-адреса, которые я не хочу (ошибка 404) в Инструментах для веб-мастеров.
Мне нужно переписать URL-адреса, которые включают --
, /-
или окончание на -
вот так:
--
с участием -
-
после /
-
... но только если URL не содержит product_info.php
.
Я пробовал с этим, но не работает ...
RewriteCond %{REQUEST_URI} !^/product_info\.php(.*)$
RewriteRule ^(.*)--(.*)$ /$1-$2 [L,R=301]
RewriteRule ^(.*)/-(.*)$ /$1/$2 [L,R=301]
RewriteRule ^(.*)-$ /$1$2 [L,R=301]
Он находится в интернет-магазине Magento с активированным кешем Varnish.
Редактировать # 1:
Да, они появляются в отчете об ошибке 404!
Под неработающим я подразумеваю: Magento говорит: «Этот документ переехал сюда». Если я щелкну там, появится "Ошибка блокировки ESI"
После product_info.php?product=TestProduct--Green--XXL
В этом случае я не хочу заменять --
к -
=> Думаю, в этом проблема.
Редактировать # 2:
Вот полный .htaccess
. Я удалил комментарии, ожидая переадресации, которую я пытаюсь заставить работать из-за большого количества места.
DirectoryIndex index.php
<IfModule mod_php5.c>
php_value memory_limit 6144M
php_value max_execution_time 18000
php_flag magic_quotes_gpc off
php_flag session.auto_start off
php_flag suhosin.session.cryptua off
php_flag zend.ze1_compatibility_mode Off
</IfModule>
<IfModule mod_security.c>
SecFilterEngine Off
SecFilterScanPOST Off
</IfModule>
<IfModule mod_deflate.c>
</IfModule>
<IfModule mod_ssl.c>
SSLOptions StdEnvVars
</IfModule>
<IfModule mod_rewrite.c>
Options +FollowSymLinks
RewriteEngine on
RewriteCond %{REQUEST_URI} ^/rma/
RewriteRule ^ - [L]
#RewriteCond %{REQUEST_URI} !^/product_info(.*)
#RewriteRule ^(.*)--(.*)$ /$1-$2 [L,R=301]
#RewriteCond %{REQUEST_URI} !^/product_info(.*)
#RewriteRule ^(.*)/-(.*)$ /$1/$2 [L,R=301]
#RewriteCond %{REQUEST_URI} !^/product_info(.*)
#RewriteRule ^(.*)-$ /$1$2 [L,R=301]
RewriteRule ^api/rest api.php?type=rest [QSA,L]
RewriteRule .* - [E=HTTP_AUTHORIZATION:%{HTTP:Authorization}]
RewriteCond %{REQUEST_METHOD} ^TRAC[EK]
RewriteRule .* - [L,R=405]
RewriteCond %{REQUEST_URI} !^/(media|skin|js)/
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
RewriteCond %{REQUEST_FILENAME} !-l
RewriteRule .* index.php [L]
</IfModule>
AddDefaultCharset Off
<IfModule mod_expires.c>
ExpiresDefault "access plus 1 year"
</IfModule>
Order allow,deny
Allow from all
<Files RELEASE_NOTES.txt>
order allow,deny
deny from all
</Files>
<Files cron.php>
Order allow,deny
Deny from all
</Files>
В RewriteCond
директива применяется только к не замужем RewriteRule
что следует за ним. Итак, вам нужно повторить это условие для каждого правила. Например:
Options +FollowSymLinks
RewriteEngine On
RewriteCond %{REQUEST_URI} !^/product_info\.php
RewriteRule (.*)--(.*) /$1-$2 [L,R=301]
RewriteCond %{REQUEST_URI} !^/product_info\.php
RewriteRule (.*)/-(.*) /$1/$2 [L,R=301]
RewriteCond %{REQUEST_URI} !^/product_info\.php
RewriteRule (.*)-$ /$1 [L,R=301]
В качестве альтернативы вы можете включить одно исключение в начало правил, чтобы избежать перезаписи /product_info.php
файл. Но это зависит от остальной части вашего файла .htaccess, поскольку он исключает /product-info.php
от переписывания вообще. Например:
RewriteRule ^product_info\.php$ - [L]
Я также удалил конечный (.*)$
на CondPattern - в данном примере это лишнее. Как якоря, когда у вас есть кактус-все .*
шаблон (по умолчанию жадный).
Перед тестированием убедитесь, что все ваши кеши чисты. Часто проще проверить с помощью 302
(временное) перенаправление, поскольку они не кэшируются (или не должны храниться).