Комплексный редирект на https://www.

d0ublezer0

Мой дом здесь!
Регистрация
21 Май 2009
Сообщения
367
Реакции
201
Помогите пожалуйста с таким вопросом

Как составить правило для .htaccess чтобы выполнялся редирект с
Для просмотра ссылки Войди или Зарегистрируйся
Для просмотра ссылки Войди или Зарегистрируйся
Для просмотра ссылки Войди или Зарегистрируйся
на
Для просмотра ссылки Войди или Зарегистрируйся
?

в сети нашел только правила для non-www to www
Код:
RewriteCond %{HTTP_HOST} !^www\.
RewriteRule ^(.*)$ http://www.%{HTTP_HOST}/$1 [R=301,L]
и для non-https to https
Код:
RewriteCond %{HTTPS} !on
RewriteRule (.*) https://%{HTTP_HOST}%{REQUEST_URI}
а вместе они не работают
 
а вместе они не работают
Что значит не работают? В том виде, в котором они сейчас - они будут давать бесконечный цикл переадресаций, но пробовали ли вы сделать вот так?
Код:
RewriteCond %{HTTP_HOST} !^www\.
RewriteRule (.*) https://www.%{HTTP_HOST}/$1 [R=301,L]

RewriteCond %{HTTPS} !on
RewriteRule (.*) https://www.%{HTTP_HOST}/$1 [R=301,L]

Должно всё отрабатывать...
 
О, вот так вроде работает:
Код:
RewriteBase /
RewriteCond %{HTTP_HOST} !^www\.
RewriteRule ^(.*)$ http://www.%{HTTP_HOST}/$1 [R=301,L]

RewriteCond %{THE_REQUEST} !^POST
RewriteCond %{THE_REQUEST} ^[A-Z]{3,9}\ /index\.php\ HTTP/
RewriteCond %{SERVER_PORT}>s ^(443>(s)|[0-9]+>s)$
RewriteRule ^index\.php$ http%2://%{HTTP_HOST}/ [R=301,L]
Всё верно? Ничем не чревато?
Еще и index.php из url убрался

Что значит не работают? В том виде, в котором они сейчас - они будут давать бесконечный цикл переадресаций, но пробовали ли вы сделать вот так?
Код:
RewriteCond %{HTTP_HOST} !^www\.
RewriteRule (.*) https://www.%{HTTP_HOST}/$1 [R=301,L]

RewriteCond %{HTTPS} !on
RewriteRule (.*) https://www.%{HTTP_HOST}/$1 [R=301,L]

Должно всё отрабатывать...
C вашим вариантом получается Для просмотра ссылки Войди или Зарегистрируйся
 
О, вот так вроде работает:
Код:
RewriteBase /
RewriteCond %{HTTP_HOST} !^www\.
RewriteRule ^(.*)$ http://www.%{HTTP_HOST}/$1 [R=301,L]

RewriteCond %{THE_REQUEST} !^POST
RewriteCond %{THE_REQUEST} ^[A-Z]{3,9}\ /index\.php\ HTTP/
RewriteCond %{SERVER_PORT}>s ^(443>(s)|[0-9]+>s)$
RewriteRule ^index\.php$ http%2://%{HTTP_HOST}/ [R=301,L]
Всё верно? Ничем не чревато?
Еще и index.php из url убрался
Жестяк... Я таких монстров уже очень давно не встречал. Неужели мои правила вам не понравились? :)
По сути - ничем не чревато... ещё и своим устрашающим видом будут отпугивать молодых прогеров, если они захотят внести какие-либо правки в .htaccess без разрешения.
 
PS: ну и насколько я вижу - при переадрессации урлов вида: Для просмотра ссылки Войди или Зарегистрируйся - частичка "any_url_here: будет потеряна. То бишь вы получите не постраничный редирект, а редирет со всех "не правильных страниц" на "правильную главную".
 
Чуть выше я ответил:
C вашим вариантом получается Для просмотра ссылки Войди или Зарегистрируйся
т.е. двойное www
 
Не работает, увы.
Неверное перенаправление на странице
Firefox определил, что сервер перенаправляет запрос на этот адрес таким образом, что он никогда не завершится.
Вот полный листинг .htaccess:
Код:
<IfModule mod_expires.c>
  <FilesMatch \.(gif|png|jpg|jpeg|ogg|mp4|mkv|flv|swf|wmv|asf|asx|wma|wax|wmx|wm)$>
    ExpiresDefault "access plus 1 year"
  </FilesMatch>
  ExpiresActive on
  ExpiresByType image/jpeg "access plus 7 day"
  ExpiresByType image/gif "access plus 7 day"
  ExpiresByType image/png "access plus 7 day"
  <FilesMatch \.(css|js)$>
    ExpiresDefault "access plus 1 year"
  </FilesMatch>
  ExpiresByType text/css "access plus 1 year"
  ExpiresByType application/javascript "access plus 1 year"
</IfModule>
##
# @package        Joomla
# @copyright    Copyright (C) 2005 - 2013 Open Source Matters. All rights reserved.
# @license        GNU General Public License version 2 or later; see LICENSE.txt
##

##
# READ THIS COMPLETELY IF YOU CHOOSE TO USE THIS FILE!
#
# The line just below this section: 'Options +FollowSymLinks' may cause problems
# with some server configurations.  It is required for use of mod_rewrite, but may already
# be set by your server administrator in a way that dissallows changing it in
# your .htaccess file.  If using it causes your server to error out, comment it out (add # to
# beginning of line), reload your site in your browser and test your sef url's.  If they work,
# it has been set by your server administrator and you do not need it set here.
##

## Can be commented out if causes errors, see notes above.
Options +FollowSymLinks

## Mod_rewrite in use.

RewriteEngine On

## Begin - Rewrite rules to block out some common exploits.
# If you experience problems on your site block out the operations listed below
# This attempts to block the most common type of exploit `attempts` to Joomla!
#
# Block out any script trying to base64_encode data within the URL.
RewriteCond %{QUERY_STRING} base64_encode[^(]*\([^)]*\) [OR]
# Block out any script that includes a <script> tag in URL.
RewriteCond %{QUERY_STRING} (<|%3C)([^s]*s)+cript.*(>|%3E) [NC,OR]
# Block out any script trying to set a PHP GLOBALS variable via URL.
RewriteCond %{QUERY_STRING} GLOBALS(=|\[|\%[0-9A-Z]{0,2}) [OR]
# Block out any script trying to modify a _REQUEST variable via URL.
RewriteCond %{QUERY_STRING} _REQUEST(=|\[|\%[0-9A-Z]{0,2})
# Return 403 Forbidden header and show the content of the root homepage
RewriteRule .* index.php [F]
#
## End - Rewrite rules to block out some common exploits.

## Begin - Custom redirects

RewriteBase /
RewriteCond %{HTTP_HOST} !^www\.
RewriteRule (.*) https://www.%{HTTP_HOST}/$1 [R=301,L]

RewriteCond %{HTTPS} !on
RewriteRule (.*) https://%{HTTP_HOST}/$1 [R=301,L]

## Begin - Joomla! core SEF Section.
#
RewriteRule .* - [E=HTTP_AUTHORIZATION:%{HTTP:Authorization}]
#
# If the requested path and file is not /index.php and the request
# has not already been internally rewritten to the index.php script
RewriteCond %{REQUEST_URI} !^/index\.php
# and the request is for something within the component folder,
# or for the site root, or for an extensionless URL, or the
# requested URL ends with one of the listed extensions
RewriteCond %{REQUEST_URI} /component/|(/[^.]*|\.(php|html?|feed|pdf|vcf|raw))$ [NC]
# and the requested path and file doesn't directly match a physical file
RewriteCond %{REQUEST_FILENAME} !-f
# and the requested path and file doesn't directly match a physical folder
RewriteCond %{REQUEST_FILENAME} !-d
# internally rewrite the request to the index.php script
RewriteRule .* index.php [L]
#
## End - Joomla! core SEF Section.
 
Не работает, увы.
Странно. Никто никому не мешает...
версия с https ведь нормально работает если её в URL вбивать?
Если с работой правильного URL всё ок - пробуем 2 варианта:
1) добавляем одну проверку (она должна как-бы исключить зацикливание) :
Код:
RewriteCond %{HTTP_HOST} !^www\.
RewriteRule (.*) https://www.%{HTTP_HOST}/$1 [R=301,L]

RewriteCond %{HTTP_HOST} www\.
RewriteCond %{HTTPS} !on
RewriteRule (.*) https://%{HTTP_HOST}/$1 [R=301,L]
2) указываем явно адрес сайта, дабы исключить "непонимания" (не так универсально при смене хостинга, но должно исключить ошибки) :
Код:
RewriteCond %{HTTP_HOST} !^www\.site\.ru
RewriteRule (.*) https://www.site\.ru/$1 [R=301,L]

RewriteCond %{HTTPS} !on
RewriteRule (.*) https://www.site.ru/$1 [R=301,L]
 
версия с https ведь нормально работает если её в URL вбивать?
Опытным путём выяснилось, что перенаправление на https выполняется в любом случае, даже если обсуждаемых директив не присутствует. Полагаю, это делается средствами движка.
Тогда получается, оставить нужно только одно правило:
Код:
RewriteCond %{HTTP_HOST} !^www\.
RewriteRule (.*) https://www.%{HTTP_HOST}/$1 [R=301,L]
 
Назад
Сверху