Назад | Перейти на главную страницу

htaccess rewritecond для перезаписи 404 ошибок на исключенных URL

У меня проблема с моим .htaccess файл.

У Google есть проиндексированные URL-адреса, которые я не хочу (ошибка 404) в Инструментах для веб-мастеров.

Мне нужно переписать URL-адреса, которые включают --, /- или окончание на - вот так:

  1. заменить -- с участием -
  2. удалить - после /
  3. удалить окончание -

... но только если 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 (временное) перенаправление, поскольку они не кэшируются (или не должны храниться).