как использовать перенаправление на другой сайт в 2022 году
Основные понятия: протокол HTTP, кода ответа, перенаправление
Протокол HTTP, или Hypertext Transfer Protocol (протокол передачи гипертекста), — это основной протокол прикладного уровня, с помощью которого осуществляется всем привычный серфинг по Сети с помощью браузера. Характерной особенностью этого протокола является отсутствие данных о предыдущем состоянии между разными запросами клиента, выполненными с его помощью. На каждый запрос клиентского приложения (частным случаем которого является браузер) сервер, которому он был адресован, генерирует некоторый ответ. В начале каждого ответа находится один из предопределенных кодов, или статусов, ответа протокола HTTP, затем идут заголовки и может присутствовать тело ответа.
В рамках данной статьи будут рассмотрены только коды ответа для перенаправлений. Итак, для редиректов выделена группа кодов от 300 до 399. В предыдущей версии спецификации протокола HTTP было предусмотрено максимальное количество перенаправлений равное 5, поэтому при использовании редиректов нужно иметь в виду данное ограничение, которое до сих пор может быть реализовано в устаревших приложениях.
Само понятие перенаправления предполагает, что при получении кода ответа 3xx клиентское приложение, в частности браузер, самостоятельно или с помощью пользователя принимает решение о том, что нужно делать дальше.
Виды перенаправлений
На текущий момент существует 9 видов редиректов:
- 300 Multiple Choices
- 301 Moved Permanently
- 302 Found
- 303 See Other
- 304 Not Modified
- 305 Use Proxy
- 306 Reserved
- 307 Temporary Redirect
- 308 Permanent Redirect
Далее подробно рассмотрим все эти виды и случаи, когда их нужно использовать.
Множественный выбор, Multiple Choices, HTTP-код 300
Используется когда один и тот же ресурс в Сети имеет несколько представлений, у каждого из которых есть свое расположение, для различных клиентов. Например, для пользователей, зашедших на сайт со стационарного ПК или ноутбука, будет показана обычная версия сайта, а для пользователей мобильных устройств отобразится облегченная версия сайта, которая учитывает особенности аппаратного обеспечения этих устройств.
Пример несколько надуманный, т.к. для реализации подобного поведения ранее просто использовались другие протоколы передачи данных (например, WML), а сейчас используется адаптивная верстка.Перемещено постоянно, Moved Permanently, HTTP-код 301
Это самый распространенный вид редиректа, с которым сталкивается каждый веб-мастер. Он сообщает клиентскому приложению, что запрашиваемый ресурс был перемещен и теперь находится по другому адресу. В чем же важность этого перенаправления? Рассмотрим примеры, когда не обойтись без 301-го редиректа.
- Публикация на сайте переносится в другой раздел или переименовывается, и ее адрес автоматически изменяется программой управления сайтом. В данном случае использование 301-го перенаправления позволит обновить индекс поисковых систем и не потерять позиции, завоеванные с помощью поисковой оптимизации.
- Сайт переносится на новый домен. В этом случае до тех пор, пока есть контроль над старым доменом, нужно установить на нем перенаправление на новый домен, чтобы не потерять позиции в поисковых системах и посетителей/клиентов, которые запомнили адрес (например, в своих закладках) и заходят по прямой ссылке.
- Слияние сайтов, резервирование для сайта схожего по написанию домена или же имени домена в другой доменной зоне. Резервирование может быть полезно, если мы хотим обезопасить себя от возможных сайтов-конкурентов с созвучным названием. При слиянии сайтов не стоит отказываться от ставшего ненужным домена, т.к. данная экономия может привести к большим потерям трафика или же облегчить выход в ту же нишу конкурента с использованием вашего старого доменного имени, которое успело набрать некоторый вес для поисковиков из-за всего возраста.
Найдено, Found, HTTP-код 302
Рапортует о том, что запрошенный ресурс временно располагается по другому адресу и может быть передан клиенту. Используется в работе современных веб-серверов, сервисов укорачивания ссылок (сокращение URL).
Смотрите другие источники, See Other, HTTP-код 303
Появился в версии протокола HTTP 1.1. Во многом схож с кодом 302. Используется для более корректного перенаправления, если клиентское приложение использует для запроса метод POST (например, при отправке форм в браузере). При этом предложенный вместо запрошенного адрес ресурса является временным и не должен быть запомнен вызывающим приложением.
Не изменено, Not Modified, HTTP-код 304
Сообщает клиенту, что запрашиваемый ресурс не был изменен с момента времени, указанного в специальном заголовке запроса If-Modified-Since или If-Match. Активно используется в работе браузеров, когда на сервере включено кеширование содержимого сайта. Если запрашиваемая страница или другой ресурс (картинка, сценарий, стили оформления страницы) не были изменены, то браузер при получении кода ответа 304 не производит загрузку с сервера, а рассчитывает на свой локальный кеш. Это экономит пропускную способность канала клиента и сервера и приводит к ускорению загрузки содержимого. Например, при правильно настроенном кэшировании страница сайта, которую мы недавно посетили, будет грузиться на порядок быстрее, чем та, которую мы еще не смотрели.
Используйте прокси, Use Proxy, HTTP-код 305
Появился в версии протокола HTTP 1. 1. Предписывает использовать для доступа к ресурсу прокси-сервер (промежуточный сервер), данные которого передаются в заголовке ответа Location. От пользователя в таком случае ничего не требуется делать, т.к. всю работу должна автоматически выполнить клиентская программа.
Переключите прокси-сервер, Switch Proxy, HTTP-код 306
Данный код использовался в предыдущей версии спецификации протокола. В настоящий момент код 306 не несет никакой смысловой нагрузки. Тем не менее, он остается зарезервирован.
Временное перенаправление, Temporary Redirect, HTTP-код 307
Появился в версии протокола HTTP 1.1 вместе с кодом 303 для разрешения коллизий с временным перенаправлением, которые существовали в предыдущей версии протокола HTTP при наличии только 302-го кода. При перенаправлении метод запроса не может быть изменен с POST на GET.
Постоянное перенаправление, Permanent Redirect, HTTP-код 308
Пока находится в стадии черновика. Является аналогом кода 301 за исключением того, что при перенаправлении метод запроса не может быть изменен с POST на GET. Использование кода 308 позволяет улучшить перенаправление запросов из HTML- форм по методу POST к ресурсам, которые поменяли свой адрес на постоянной основе. Он дополняет набор кодов 301, 302, 307 для выполнения постоянных и временных перенаправлений.
В качестве заключения
При работе над сайтом веб-мастер должен хорошо понимать, когда и как устанавливать 301-редирект. Другие значимые статусы ответа используются исключительно веб-программистами или же программистами, которые работают над серверным программным обеспечением. Коды от 309 до 399 в настоящий момент не используются, но могут быть задействованы в будущем.
Материалы по теме
- Реестр кодов ответа в протоколе HTTP.
- Спецификация протокола HTTP версии 1.1 — RFC 2616.
- Краткое описание HTTP-кодов ответа.
- Черновик спецификации по HTTP Status Code 308.
Настройка редиректа, перенаправление с одного адреса на другой без htaccess (переадресация) домена
Виды редиректов
Редирект для домена — перенаправление с одного адреса (домена) на другой. Подробнее об этой функции на DomainParking.ru читайте в статье.
Существует 2 типа редиректа.
301-й редирект (код ответа браузера 301 moved permanently) — расценивается поисковыми системами как постоянный редирект и происходит «склеивание» доменов, и все показатели «склеенных» доменов для поисковых систем объединяются.
Доступен 301-й редирект исключительно на шаблонах «Пользовательский редирект».
302-й редирект (код ответа браузера 302 temporary redirect) — временное перенаправление и «склеивание» не происходит. Таким образом ваш домен поисковики воспринимают как самостоятельную единицу, и, в случае если вы решите сделать на нем сайт или продать, то вам не придется ждать пока поисковики «расклеят» домены, что может длиться более месяца.
Доступен 302-й редирект как на на шаблоне «Базовый редирект», так и на шаблонах «Пользовательский редирект».
Исходя из этого приходим к выводу, что 302 редирект не подойдет для следующих ситуаций:
- склейка домена с сайтом для передачи ему SEO параметров;
- перенаправление пользователей со старого домена на новый.
Упрощенное добавление редиректа
Теперь редиректы можно добавить массово, указав список доменов и одну общую цель для всех добавляемых доменов.
При необходимости, вы можете указать категорию или иной шаблон из пользовательских редиректов, а также загрузить список доменов с настройками из файла.
Добавление редиректа из файла
Теперь редиректы можно добавить из текстового файла в формате обычных шаблонов:
site1.ru::rd_0:0::http://site2.ru — для базового редиректа (rd_0)
site1.ru::rd_7:0::http://site22.ru — для пользовательского редиректа (rd_7) номер можно узнать в адресной строке браузера:
Или сделав бекап доменов в Настройках аккаунта и скачав его в Отчетах.
Поддерживается так же упрощенный формат, который был доступен в старой версии редиректов:
site1.ru|site2.ru
где site1.ru — домен с которого будет идти редирект, site2.ru — цель редиректа (домен, на который будем перенаправлять), «|» — разделитель.
Например:
После добавления записи смените DNS-серверы перенаправляемого домена (site1.ru) на новые: ns1.domainparking.ru и ns2.domainparking.ru.
Готово! Через 2-6 часов парковка будет перенаправлять посетителей на целевой сайт.
Как настроить шаблон «Базовый редирект»
Шаблон «Базовый редирект» подойдет в случаях, когда нужно, чтобы один/несколько доменов вели на другой целевой адрес. Мы сделали эту процедуру проще. Теперь редиректы на один адрес можно настраивать массово
Чтобы настроить шаблон «Базовый редирект»:
- Авторизуйтесь в личном кабинете.
- Перейдите в раздел Настройки.
- Введите целевой адрес с https:// в графе
- Нажмите Сохранить ниже.
Готово! Этот редирект будет использоваться в качестве шаблона Базовый редирект.
Далее вам нужно подключить редирект к одному/нескольким доменам. Для этого:
- Перейдите в раздел Припаркованные домены.
- В строке домена/доменов, с которых должно идти перенаправление на целевой адрес в столбце «Шаблон» установите Базовый редирект:
Готово! Выбранные домены будут вести на адрес, установленный в URL для шаблона.
Все домены c редиректами отображаются во вкладке Редиректы:
Для каждого домена на базовом редиректе можно добавить индивидуальный URL. Если домен переключить на другой шаблон, этот URL будет использоваться и в шаблоне SALE (как ссылка на второй кнопке шаблона) и в шаблоне iFrame.
Как настроить пользовательский шаблон редиректов?
Пользовательский шаблон редиректов подойдет для более гибкой настройки редиректов. Создав пользовательский шаблон, вы сможете настроить типы редиректа (301 — постоянный или 302 — временный) и несколько адресов, который поочередно будут открываться при переходе на домен. Также вы сможете установить приоритеты для них.
Пользовательские шаблоны можно использовать для А/Б-тестирований.
Чтобы создать пользовательский шаблон:
- Перейдите в новый раздел Списки URL.
- Нажмите Добавить “Список перенаправлений”:
- Введите название шаблона, поставьте галочку напротив Навечно, если хотите сделать постоянный редирект (301) или снимите галочку, если хотите настроить временный редирект (302). Временный редирект подходит для случаев, когда вы устанавливаете несколько целевых сайтов для перенаправления. Введите несколько URL-адрес с https://, выставьте приоритет (чем больше число, тем чаще будет открываться именно этот адрес) и нажмите Добавить:
Готово! Шаблон редиректа появится в разделе. Теперь вы можете подключить его к доменам в разделе Припаркованные домены:
Пользовательские редиректы можно использовать для того, чтобы направить отдельную группу доменов на один URL и собирать отдельную статистику по этой группе доменов в разделе Статистика/Шаблоны. Также они используются для быстрой смены URL.
Добавление доменов с редиректами в Магазин доменов
- Перейдите в раздел Припаркованные домены.
- Перейдите в настройки нужного домена.
- В блоке Шаблон установите «Базовый редирект» и нажмите Сохранить: Здесь же вы можете установить другой целевой URL для отдельного домена.
- Левее поставьте галочку напротив пункта Участвует в продаже. Здесь же вы можете добавить описание, заголовок и цену доменов с редиректами. Сохраните изменения:
Готово! Вы выставили домен с редиректом в Магазине доменов.
Как узнать статистику редиректов
Посещения по редиректам отображается в разделе Статистика в одноименной вкладке:
Также вы можете перейти во вкладку Шаблоны и посмотреть посещения по конкретному шаблону редиректов:
Вспомогательные функции Django | Документация Django 4.0
Пакет django. shortcuts
собирает вспомогательные функции и классы, которые охватывают несколько уровней MVC. Другими словами, эти функции/классы для удобства вводят управляемую связь.
render()
-
render
(request, template_name, context=None, content_type=None, status=None, using=None)[исходный код] Объединяет заданный шаблон с заданным контекстным словарем и возвращает объект
HttpResponse
с этим визуализированным кодом.Django не предоставляет функцию быстрого доступа, которая возвращает
TemplateResponse
, потому что конструкторTemplateResponse
предлагает тот же уровень удобства, что иrender()
.
Обязательные аргументы
request
- Объект запроса, использованный для генерации этого ответа.
template_name
- Полное имя используемого шаблона или последовательность имен шаблонов. Если указана последовательность, будет использован первый существующий шаблон. Смотрите документацию по загрузке шаблонов для получения дополнительной информации о том, как найти шаблоны.
Необязательные аргументы
context
- Словарь значений для добавления в контекст шаблона. По умолчанию это пустой словарь. Если значение в словаре является вызываемым, представление вызовет его непосредственно перед отрисовкой шаблона.
content_type
- Тип MIME для использования в итоговом документе. По умолчанию —
text/html
. status
- Код состояния для ответа. По умолчанию
200
. using
- Параметр
NAME
шаблонизатора, который будет использоваться для загрузки шаблона.
Пример
В следующем примере отображается шаблон myapp/index.html
с типом MIME application/xhtml+xml:
from django. shortcuts import render def my_view(request): # View code here... return render(request, 'myapp/index.html', { 'foo': 'bar', }, content_type='application/xhtml+xml')
Этот пример эквивалентен:
from django.http import HttpResponse from django.template import loader def my_view(request): # View code here... t = loader.get_template('myapp/index.html') c = {'foo': 'bar'} return HttpResponse(t.render(c, request), content_type='application/xhtml+xml')
redirect()
-
redirect
(to, *args, permanent=False, **kwargs)[исходный код] Возвращает
HttpResponseRedirect
на соответствующий URL-адрес для переданных аргументов.Аргументами могут быть:
- Модель: будет вызвана функция модели
get_absolute_url()
. - Имя представления, возможно с аргументами:
reverse()
, будет использоваться для обратного разрешения имени. - Абсолютный или относительный URL-адрес, который будет использоваться как есть для местоположения перенаправления.
По умолчанию выдает временное перенаправление; передайте
permanent=True
, чтобы выполнить постоянное перенаправление.- Модель: будет вызвана функция модели
Примеры:
Вы можете использовать функцию redirect()
разными способами.
Передавая некоторый объект; будет вызван метод этого объекта
get_absolute_url()
для определения URL перенаправления:from django.shortcuts import redirect def my_view(request): ... obj = MyModel.objects.get(...) return redirect(obj)
Путем передачи имени представления и, возможно, некоторых позиционных или ключевых аргументов; URL-адрес будет преобразован в обратном порядке с использованием метода
reverse()
:def my_view(request): ... return redirect('some-view-name', foo='bar')
Передавая жестко запрограммированный URL-адрес для перенаправления на:
def my_view(request): . .. return redirect('/some/url/')
Это также работает с полными URL:
def my_view(request): ... return redirect('https://example.com/')
По умолчанию redirect()
возвращает временное перенаправление. Все вышеперечисленные формы принимают permanent
аргумент; если установлено значение True
, будет возвращено постоянное перенаправление:
def my_view(request): ... obj = MyModel.objects.get(...) return redirect(obj, permanent=True)
get_object_or_404()
-
get_object_or_404
(klass, *args, **kwargs)[исходный код] Вызывает
get()
для данного менеджера модели, но вызывает исключениеHttp404
вместоDoesNotExist
.
Обязательные аргументы
klass
- Класс
Model
,Manager
или экземплярQuerySet
из которого получает объект. **kwargs
- Параметры поиска, которые должны быть в формате, принятом
get()
иfilter()
.
Пример
Следующий пример получает объект с первичным ключом 1 из MyModel
:
from django.shortcuts import get_object_or_404 def my_view(request): obj = get_object_or_404(MyModel, pk=1)
Этот пример эквивалентен:
from django.http import Http404 def my_view(request): try: obj = MyModel.objects.get(pk=1) except MyModel.DoesNotExist: raise Http404("No MyModel matches the given query.")
Наиболее распространенный вариант использования — передача Model
, как показано выше. Однако вы также можете передать экземпляр QuerySet
:
queryset = Book.objects.filter(title__startswith='M') get_object_or_404(queryset, pk=1)
Приведенный выше пример немного надуман, поскольку он эквивалентен выполнению:
get_object_or_404(Book, title__startswith='M', pk=1)
но это может быть полезно, если вам передали переменную queryset
откуда-то еще.
Наконец, вы также можете использовать Manager
. Это полезно, например, если у вас есть собственный менеджер:
get_object_or_404(Book.dahl_objects, title='Matilda')
Вы также можете использовать связанные менеджеры
:
author = Author.objects.get(name='Roald Dahl') get_object_or_404(author.book_set, title='Matilda')
Примечание: как и в случае с get()
, исключение MultipleObjectsReturned
будет вызвано, если будет найдено более одного объекта.
get_list_or_404()
-
get_list_or_404
(klass, *args, **kwargs)[исходный код] Возвращает результат
filter()
для заданного менеджера модели, приведенного к списку, вызываяHttp404
, если результирующий список пустой.
Обязательные аргументы
klass
Model
,Manager
илиQuerySet
, из которого можно получить список.**kwargs
- Параметры поиска, которые должны быть в формате, принятом
get()
иfilter()
.
Пример
Следующий пример получает все опубликованные объекты из MyModel
:
from django.shortcuts import get_list_or_404 def my_view(request): my_objects = get_list_or_404(MyModel, published=True)
Этот пример эквивалентен:
from django.http import Http404 def my_view(request): my_objects = list(MyModel.objects.filter(published=True)) if not my_objects: raise Http404("No MyModel matches the given query.")
Загрузка файлов
Общие представления
Вернуться на верх
Содержание
- Вспомогательные функции Django
render()
- Обязательные аргументы
- Необязательные аргументы
- Пример
redirect()
- Примеры:
get_object_or_404()
- Обязательные аргументы
- Пример
get_list_or_404()
- Обязательные аргументы
- Пример
Дополнительно
- Алфавитный указатель
- Содержание модулей Python
Новые вопросы с меткой [redirect]
Задать вопрос
Редирект — техника, применяемая во Всемирной паутине для того, чтобы веб-страница была доступна под несколькими URL.
- Подробнее…
- Лучшие участники
- Синонимы
417 вопросов
Новые
Текущие
Конкурсные
Неотвеченные
ФильтрацияБез ответов
Без принятого ответа
Объявлен конкурс
СортировкаОбновлённые
Наивысший рейтинг
Наиболее частые
Конкурс скоро заканчивается
МеткиОтслеживаемые метки
Указанные ниже метки:
0 голосов
1 ответ
19 показов
Внезапный редикрет
Использую библиотеку simplejwt для авторизации на сайте. Протестировал на локальной машине всё ок, клонировал проект на сервак и при авторизации начали странные редиректы (см. скрин). IP:ADDRESS [21/…
- python
- http
- redirect
- django-rest-framework
0 голосов
0 ответов
11 показов
Помогите настроить return_url на юкассе, он имеет одно значение а нужно 2
столкнулся с проблемой на юкассе — знаение для return_url одно, а сценария на сайте — два: Человек нажал на кнопку оплаты, но не оплатив нажал вернуться в магазин Человек произвел оплату, нажал …
- php
- redirect
0 голосов
1 ответ
18 показов
Laravel route без слэшей
сайт недавно был перенесен на laravel, до этого все адреса были вида: https://домен. ру/category/ А когда прописали все роуты, адреса начали идти: https://домен.ру/category Т.е. ларавел убирает все …
- laravel
- url
- redirect
- laravel-8
0 голосов
1 ответ
29 показов
Как сделать переход страницы на другую в WordPress
Возможно, данный вопрос уже был задан, но попробую задать с моей точки зрения. Нужно сделать переход в навигации на ru.php (рис.), возможно ли это сделать стандартной html структурой, к примеру: <a …
- php
- wordpress
- redirect
- href
0 голосов
0 ответов
15 показов
Как обнаружить iframe или другой фрод на сайте, откуда пришел редирект
Всем привет! Мне нужно на моей странице, куда приходит редирект проверить наличие iframe и другого фрода. Я вот сейчас не очень понимаю как я пойму был ли iframe на том сайте откуда пришел редирект. …
- javascript
- redirect
- iframe
-1 голос
1 ответ
27 показов
как убрать путь в nginx и сделать redirect?
Есть запрсы условно https://example.com/ru/paths или https://example.com/en/paths, после ru и en может буть любой путь и с параметрами и без. Вопрос как убрать ru и en и оставить например https://…
- nginx
- seo
- redirect
0 голосов
0 ответов
9 показов
Keycloak. Invalid parameter: redirect_uri
Добрый день пытаюсь разобраться с подключением keycloak к spring boot приложению, однако при переходе на страницу с авторизацией появляется ошибка с неверным redirect_uri. Не понимаю где и как его …
- spring-boot
- redirect
- boot
- keycloak
-1 голос
0 ответов
19 показов
Привет всем! Ранее работал парсинг этой страницы https://my.licard.com/ru/login (админы добавили редиректы) Возвращает пустую строку, вместо html
$arHeaders = array( «User-Agent:Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.9.2.13) Gecko/20101203 Firefox/3.6.13», «Accept:text/html,application/xhtml+xml,…
- php
- парсер
- curl
- redirect
0 голосов
0 ответов
24 показа
Переход на другой url с передачей токена авторизации
Пользователь работает в веб приложении, при нажатии кнопки получает токен авторизации, переходит в другую систему со своим адресом, при этом автоматически аутентифицируется во второй системе под тем . ..
- javascript
- redirect
-1 голос
2 ответа
36 показов
почему не работает redirect Django
у меня есть такой код из views.py который написан с помощью документации, но он не работает и вместо редиректа на главную страницу выдет в адресной строке только ‘/?’. Помогите пожалуйста сказав что …
- django
- redirect
- backend
0 голосов
1 ответ
45 показов
Как сделать редирект всех страниц сайта на другой домен?
Как сделать редирект всех страниц сайта (около 5000) на другой домен через .htaccess? Например, с site.ru на new-site.ru
- php
- .htaccess
- сервер
- redirect
0 голосов
0 ответов
23 показа
Три последовательных 301 редиректа объединить в один
Помогите пожалуйста объединить 301 последовательных редиректы в один. Пытался сам, но чего то я не могу понять. http://www.example.com/index.php?asd=asd -> https://example.com Нужно : редирект с …
- php
- .htaccess
- redirect
- редирект
- 301
0 голосов
0 ответов
8 показов
Настройка редиректа без .html на .html
необходимо сделать редирект к примеру: https://домен/index.html мне необходимо чтобы если я убирал .html возвращало на .html https://домен/index = https://домен/index.html КОД правил, ну чет не …
- redirect
- dle
0 голосов
0 ответов
31 показ
Почему после переадресации в Django url изменяется в консоли, но в браузере нет?
После redirect’а url изменяется в консоли, посему я сужу об успехе, однако в браузере ничего не происходит. view.py def tables(request): if request.method == ‘POST’: text = request.POST….
- django
- post
- redirect
0 голосов
0 ответов
11 показов
Как сделать нужный редирект в .htaccess
Нужно сделать редирект с этого url: https://mysite.com/item> на https://mysite.com/item, но .htaccess не принимает символ >
- .htaccess
- redirect
на странице
Как сделать HTML-перенаправление на другую страницу: полное руководство
TL;DR — HTML-перенаправление автоматически перенаправляет посетителя веб-сайта на другой сайт.
Содержание
- 1. Что такое перенаправление HTML?
- 2. Синтаксис кода перенаправления HTML
- 3. Зачем задерживать перенаправление в HTML?
- 4. Перенаправление HTML: полезные советы
Что такое перенаправление HTML?
Перенаправление происходит, когда пользователь вводит URL-адрес, но он меняется, и вместо этого браузер перенаправляет их на другой. Создатели веб-сайтов полагаются на них, когда им нужно изменить структуру своего сайта или расположение конкретной страницы. Конечно, вы также можете перенаправить на совершенно другой веб-сайт.
При работе с протоколом передачи гипертекста (HTTP) необходимо иметь общее представление о его кодах ответов . Они состоят из трех цифр, первая из которых определяет их тип:
Код ответа | Тип ответа |
---|---|
1хх | Информационный ответ (например, обработка) |
2хх | Успешный ответ (например, OK) |
3хх | Ответ о перенаправлении (например, перемещен навсегда) |
4хх | Ответ об ошибке на стороне клиента (например, Not Found) |
5хх | Ответ об ошибке на стороне сервера (например, Bad Gateway) |
Допустим, вы закрыли свой старый сайт и открыли новый. Если пользователь вводит URL-адрес старого в свой браузер, он возвращает код ответа 404 (не найдено). Однако, если вы используете перенаправление HTML, пользователь получит либо 301 (перемещено навсегда) или 302 (найдено). Этот код невидим для пользователя, но браузер его понимает и моментально перенаправляет пользователя на новый URL.
Синтаксис кода перенаправления HTML
Перенаправление HTML также известно как перенаправление meta refresh или просто перенаправление HTML meta. Это позволяет вам выбрать, нужна ли вам немедленная или отложенная переадресация. Если указать время задержки в секундах, пользователь будет видеть старую страницу ровно столько времени.
Чтобы сделать страницу в HTML перенаправленной на другую страницу, вы должны следовать этому синтаксису:
Пример
Как вы Как видите, для этого требуются два параметра:
-
время
представляет задержку перед тем, как браузер перенаправит пользователя на другую страницу. Определите его в секундах или введите 0, если вам нужна немедленная переадресация HTML. -
new_url
представляет URL-адрес, на который необходимо перенаправить пользователя после задержки.
В приведенном ниже примере вы можете увидеть код перенаправления HTML, который перенаправляет пользователя на веб-сайт BitDegree с задержкой в пять секунд:
Пример
Как и все метатеги, код перенаправления HTML должен быть помещен в раздел
документа. Таким образом, браузер получает определенные инструкции, которые остаются невидимыми для пользователя.Pros
- Упрощенный дизайн (без ненужной информации)
- Высококачественные курсы (даже бесплатные)
- Разнообразие функций
Основные функции
- Nanodegre сертификаты об окончании
ЭКСКЛЮЗИВ: СКИДКА 75%
Pros
- Удобная навигация
- Никаких технических проблем
- Кажется, заботятся о своих пользователях
Основные функции
- Огромное разнообразие курсов
- 30-дневная политика возврата
- Бесплатные сертификаты о завершении
As 12,99 $
Pros
. контент
- Очень прозрачные цены
Основные характеристики
- Бесплатные сертификаты об окончании
- Ориентированы на навыки работы с данными
- Гибкий график обучения
СКИДКА 75%
Зачем задерживать редирект в HTML?
Если вы не уверены, почему вы должны отложить метаперенаправление HTML, подумайте о возможности установить сообщение для пользователя. Вы можете сообщить им, что страница перемещена, а затем сразу отправить их на новую.
Другой важной причиной является небольшая вероятность неправильного отображения тега. Это может произойти, если пользователь использует какой-то древний браузер. В этом случае вы можете добавить прямая ссылка на старую страницу, которую пользователь может щелкнуть вручную, если код перенаправления HTML не сработает.
Пример
<заголовок> bitdegree.org/" /> голова> <тело>Если вы не будете перенаправлены через пять секунд, нажмите здесь.
Попробуйте в прямом эфире Учитесь на Udacity
Как видите, все, что вам нужно, чтобы добавить прямую интерактивную ссылку, — это пара тегов привязки. Обязательно поместите его в раздел
, а не в с мета-тегом перенаправления HTML: нет смысла использовать кликабельную ссылку, которую пользователь не может увидеть изначально.Перенаправление HTML: полезные советы
- Если вы не определите новый URL-адрес для перенаправления, HTML-страница просто перезагрузится по истечении указанного времени. Это может быть полезно, когда вам нужно обновить динамический контент.
- Мы советуем вам избегать задержек короче 3 секунд , поскольку это делает практически невозможным для пользователя нажатие кнопки «Назад» в своем браузере.
- Будьте осторожны, не злоупотребляйте Мета-редиректами HTML: если на вашем сайте их много, поисковые системы могут подумать, что он содержит спамить и удалить его из своего индекса.
- Вы также можете создавать перенаправления с помощью PHP, JavaScript, Ruby on Rails и Python Flask, а также на веб-серверах Apache, Nginx и Lighttpd.
Какое перенаправление следует использовать? • Йост
Как специалист по поисковой оптимизации или владелец веб-сайта, вы рано или поздно столкнетесь с редиректами. Всякий раз, когда вы удаляете страницу, меняете структуру URL-адресов или переключаетесь на новый домен, вам придется перенаправлять свои URL-адреса. Изменение URL-адресов действительно важно для вашего SEO, но может быть довольно сложным. Вот почему Yoast SEO Premium предлагает менеджер перенаправления. Это значительно упростит перенаправление URL-адресов!
Перенаправление сообщает роботам поисковых систем о том, что нужно перейти куда-то еще, временно или постоянно, для доступа к определенной странице. Выбор неправильного типа перенаправления может негативно повлиять на SEO, поэтому будьте осторожны при выборе. В этом посте объясняются различные типы перенаправлений и когда их следует использовать.
Профессиональный совет: Приводите в порядок свой контент? Облегчите себе жизнь с помощью нашей новой SEO-тренировки ! Мы найдем ваш бесхозный контент и поможем вам либо улучшить его и связать, либо удалить и перенаправить. Попробуйте и очистите этот контент!
Зачем использовать перенаправления?
В общем, вам следует стараться избегать перенаправлений, но если они вам нужны, применяйте их должным образом. Перенаправление URL-адресов является частью регулярного обслуживания вашего веб-сайта. Существует много причин для их использования, но вот наиболее распространенные:
- Удаление страницы или публикации
- Обновление или очистка контента
- Исправление проблем с каннибализацией ключевых слов
- Перенос сайта на новый домен
- Прекращение использования www в вашем домене
- Включение постоянных ссылок в WordPress
- Объединение веб-сайтов
- Изменение CMS
- Изменение структуры URL-адреса
Чтобы понять, как работают перенаправления и как вы можете влиять на то, что сервер возвращает браузеру, вам необходимо знать о кодах состояния HTTP. . Код состояния HTTP — это установленный номер, который сервер отправляет браузеру после определенного запроса страницы. Эти коды могут включать, например, 200, 301, 404 и 503, и каждый код служит определенной цели. Например, ошибка 404 означает, что страница не найдена. 503 означает, что сервер временно отключен для обслуживания или из-за перегрузки.
Если вы хотите, чтобы ваш сайт работал безупречно, вам необходимо знать свои коды состояния HTTP, и вы можете прочитать о них более подробно здесь: Коды состояния HTTP и что они означают для SEO.
Типы перенаправлений
Существует несколько перенаправлений, с которыми вы будете сталкиваться ежедневно, поэтому рекомендуется запомнить их:
- 301 Постоянный
- 302 Найдено
- 307 Временный08 9 на самом деле не перенаправляет, но все же полезно:
- 410 Контент удален
- 451 Контент недоступен по юридическим причинам
301 Постоянная переадресация
301 — одна из наиболее распространенных переадресаций, и вы должны использовать ее, если хотите навсегда перенаправить удаленную или перемещенную страницу, или если вы что-то изменили в своей структуре постоянных ссылок. Этот код сообщает роботам поисковых систем, что рассматриваемая страница больше недоступна в этом месте и что ее больше не следует индексировать. Если вы неправильно настроите перенаправление, есть вероятность, что ваши посетители и роботы-сканеры увидят 404 сообщения об ошибках, а это не то, чего вы хотите.
Поскольку код 301 постоянно ведет посетителей со старого URL-адреса на новый, его следует использовать только в том случае, если вы уверены, что больше никогда не будете использовать старый URL-адрес. Если вы делаете хотите снова использовать этот URL, вместо этого вам потребуется временное перенаправление. Ошибка 301 передает все значение ссылки, накопленное отброшенным URL-адресом за многие годы, на новый URL-адрес, поэтому новый URL-адрес получает или сохраняет ценность. Чтобы узнать, как реализовать переадресацию 301 с помощью WordPress, прочитайте этот пост Джимми или просто используйте менеджер перенаправления в Yoast SEO Premium.
302 Found
302 — довольно неоднозначный редирект и часто используется как временный. Код означает, что запрошенный контент найден, но находится в другом месте. Не сказано почему. Если вы хотите направить посетителей на альтернативную страницу при посещении этой конкретной страницы и хотите повторно использовать URL-адрес в будущем, используйте 302.
Поскольку это временное перенаправление, Google ожидает, что что-то вернется позже. Если вы оставите 302 в течение длительного периода времени, Google начнет рассматривать его как 301 и передавать любую ценность, которую имела эта ссылка.
307 Temporary
302 часто используются для создания временных перенаправлений, но с появлением HTTP 1.1 307 заменил его в качестве действительного временного перенаправления. В то время как 302 немного расплывчато, 307 точно указывает, что запрошенный URL-адрес был перемещен во временное место и вернется через некоторое время. Поскольку этот запрос может измениться в будущем, его следует по-прежнему отправлять с использованием исходного URL-адреса. Используйте это перенаправление, если вы уверены, что перемещение является временным и вам все равно понадобится исходный URL-адрес позже.
На самом деле не перенаправляет, но все же актуален
Помимо традиционных кодов, вы найдете еще два, которые на самом деле не перенаправляют. Тем не менее, они по-прежнему актуальны для ежедневного обслуживания вашего сайта. Вы могли видеть 410 и 451 как ваш сервер, говорящий: Эй, раньше здесь что-то было, но больше нет.
410 Контент удален
Страницы ошибок 404 — одна из самых больших проблем на веб-сайтах, и если вы посмотрите на свои показания в Google Search Console, вы обязательно найдете несколько. Они должны быть исправлены, потому что эти ошибки никому не нравятся: Google рассматривает их как признак плохого обслуживания, и они сбивают с толку посетителей. Ошибки 404 часто возникают, когда запрошенная страница или запись были удалены с сайта, а URL-адрес не был перенаправлен.
Используйте код 301 для перенаправления страниц с ошибкой 404 на соответствующую страницу или домашнюю страницу. Однако иногда вы можете предпочесть другой метод: сообщить поисковым системам и пользователям, что эта страница была удалена с переадресацией 410. Затем они узнают, что страница не вернется, и поэтому могут удалить страницу из индекса.
451 Контент недоступен по юридическим причинам
Если вам когда-нибудь не повезет, и судья прикажет вам удалить страницу, или если вы получите уведомление и запрос на удаление, присвойте удаленной странице заголовок 451. Это сообщает поисковым системам, что здесь был пост и что вы хотели выполнить этот запрос, но не можете по юридическим причинам. Узнайте, как и зачем делать заголовок 451, если вы когда-нибудь окажетесь в такой ситуации.
REGEX-перенаправления
Если вы профессиональный SEO-специалист и вам нужно выполнять сложные перенаправления, вам может понадобиться REGEX-перенаправления. С обычными вы указываете один URL-адрес источника и URL-адрес назначения. С помощью REGEX — регулярных выражений — переадресации вы можете, например, создать одну, чтобы переместить целые группы URL-адресов, содержащих ключевое слово, в новое место. Это может сэкономить вам массу времени при работе над масштабным SEO-проектом. Однако вам следует использовать REGEX только в том случае, если вы знаете, что делаете, потому что они могут легко сломать ваш сайт.
Управление перенаправлениями с помощью Yoast SEO Premium
Конечно, вы можете исправить свои перенаправления на сервере или использовать другие инструменты, но, как пользователь Yoast SEO Premium, вы имеете в своем распоряжении наилучший инструмент для работы с перенаправлениями. Менеджер перенаправления в Yoast SEO Premium помогает вам установить правильный, и всякий раз, когда вы удаляете или перемещаете страницу, Yoast SEO спросит вас, как с ней обращаться: должна ли она иметь 301 или 410? Или может 451? Диспетчер перенаправлений поддерживает перенаправления 301, 302, 307, 410 и 451, и все это в простом управлении рабочим процессом.
Работа с редиректами
Работа с редиректами — повседневная работа для многих SEO-специалистов. В этой статье были рассмотрены различные варианты перенаправления страниц и показано, как и когда их использовать. Но будьте внимательны при выборе! И не 302 весь ваш сайт, когда вы переходите на новый домен, потому что вы вызовете серьезные проблемы в будущем. Подумайте, чего вы хотите достичь, а затем выберите наиболее подходящий метод.
Подробнее: Как правильно удалить страницу с сайта »
Эдвин Тунен
Эдвин — специалист по стратегическому контенту. Прежде чем присоединиться к Yoast, он годами оттачивал свое мастерство в ведущем нидерландском журнале о веб-дизайне.
Далее!
- Событие
WordCamp Понтеведра 2022
23 — 25 сентября 2022 г. Team Yoast спонсирует WordCamp Pontevedra 2022. Щелкните здесь, чтобы узнать, будем ли мы там, кто будет там и многое другое! Узнайте, где вы можете найти нас дальше » - SEO-вебинар
Новостной вебинар Yoast SEO — 27 сентября 2022 г.
27 сентября 2022 г. Наш глава SEO, Джоно Алдерсон, будет держать вас в курсе всего, что происходит в мире SEO и WordPress. Все вебинары Yoast SEO »
Что такое код состояния временного перенаправления HTTP 307
Протокол HTTP определяет более 40 кодов состояния сервера, 9 из которых явно предназначены для перенаправления URL-адресов. Каждый код состояния перенаправления начинается с цифры 3 (HTTP 3xx) и имеет собственный метод обработки перенаправлений. Хотя некоторые из них похожи, все они по-разному заботятся о перенаправлениях.
Понимание того, как работает каждый код состояния перенаправления HTTP, имеет решающее значение для диагностики или исправления ошибок конфигурации веб-сайта.
В этом руководстве мы подробно рассмотрим коды состояния HTTP 307 Temporary Redirect и 307 Internal Redirect , включая их значение и отличия от других кодов состояния перенаправления 3xx.
Начнем!
Что такое HTTP 307
Temporary Redirect?Инженерная рабочая группа Интернета (IETF) определяет временное перенаправление 307 как:
Код состояния 307 (временное перенаправление) указывает, что целевой ресурс временно находится под другим URI, и пользовательский агент НЕ ДОЛЖЕН изменять метод запроса, если он выполняет автоматическое перенаправление на этот URI. Поскольку перенаправление может меняться со временем, клиент должен продолжать использовать исходный эффективный URI запроса для будущих запросов.
Как работает перенаправление HTTP 3xx
Прежде чем мы углубимся в ответы HTTP 307 Temporary Redirect и 307 Internal Redirect, давайте разберемся, как работает перенаправление HTTP.
Коды состояния HTTP — это ответы сервера браузеру. Каждый код состояния представляет собой трехзначное число, и первая цифра определяет тип ответа. Коды состояния HTTP 3xx подразумевают перенаправление. Они дают команду браузеру перенаправить на новый URL-адрес, который определен в заголовке Location ответа сервера.
Перенаправления HTTP 3xx в действииКогда ваш браузер сталкивается с запросом на перенаправление от сервера, он должен понимать природу этого запроса. Эти запросы обрабатываются различными кодами состояния перенаправления HTTP 3xx. Знание их всех поможет нам лучше понять 307 Temporary Redirect и 307 Internal Redirect.
Ознакомьтесь с нашим видеоруководством по временной переадресации 307 и всем переадресациям 3xx
Различные переадресации HTTP 3xx
Существует несколько типов кодов состояния переадресации HTTP 3xx. Первоначальная спецификация HTTP не включала временную переадресацию 307 и постоянную переадресацию 308, поскольку эти роли должны были выполняться 301 перемещено навсегда и 302 найдено.
Однако большинство клиентов изменили метод HTTP-запроса с POST на GET для ответов перенаправления 301 и 302, несмотря на то, что спецификация HTTP не разрешает клиентам делать это. Такое поведение потребовало введения более строгого 307 Временное перенаправление и 308 Постоянное перенаправление Коды состояния в обновлении HTTP/1.1.
Ответ HTTP 307 Internal Redirect является вариантом кода состояния 307 Temporary Redirect . Он не определен стандартом HTTP и представляет собой просто локальную реализацию браузера. Мы обсудим это позже более подробно.
В то время как коды состояния перенаправления, такие как 301 и 308, кэшируются по умолчанию, другие, такие как 302 и 307, нет. Однако вы можете сделать все ответы перенаправления кэшируемыми (или нет), добавив Cache-Control или Expires Поле заголовка ответа.
HTTP-перенаправления не такие сложныеИспользование 302, 303 или 307 для временных перенаправлений
Как видно из приведенной выше диаграммы, для временных перенаправлений у вас есть три варианта: 302, 303 или 307. Однако большинство клиентов обрабатывают статус 302. код в качестве ответа 303 и измените метод HTTP-запроса на GET. Это не идеально с точки зрения безопасности.
» RFC 1945 и RFC 2068 указывают, что клиенту не разрешено изменять метод перенаправленного запроса. Однако большинство существующих реализаций пользовательских агентов обрабатывают 302, как если бы это был ответ 303, выполняя GET для значения поля Location независимо от исходного метода запроса. Коды состояния 303 и 307 были добавлены для серверов, которые хотят однозначно указать, какая реакция ожидается от клиента. ”
— HTTP/1.1. Определения кода состояния, W3.orgТаким образом, для временных перенаправлений, когда вам необходимо поддерживать метод HTTP-запроса, используйте более строгий ответ HTTP 307 Temporary Redirect .
перенаправление /register-form.html на signup-form.html или с /login.php на /signin.php.
В случаях, когда вам нужно изменить метод запроса перенаправления на GET, вместо этого используйте ответ 303 See Other .
перенаправление запроса POST со страницы /register.php для загрузки страницы /success.html через запрос GET.
Если ваша целевая аудитория не использует устаревшие клиенты, избегайте использования ответа перенаправления 302 Found .
Понимание HTTP 307 Внутреннее перенаправление для сайтов, поддерживающих только HTTPS
Если у вас есть сайт, поддерживающий только HTTPS (что вам и следует делать), при попытке посетить его небезопасно через обычный http://, ваш браузер автоматически перенаправит на его безопасный https:// версия. Как правило, это происходит с ответом перенаправления 301 Moved Permanently от сервера.
Например, если вы посетите http://citibank.com и загрузите DevTools в Chrome и выберите вкладку Network , вы увидите все запросы, сделанные между браузером и сервером.
Первый ответ — 301 Moved Permanently , который перенаправляет браузер на HTTPS-версию сайта.
Ответ 301 перенаправляет на версию HTTPSЕсли мы углубимся в поля Headers первого запроса, то увидим, что заголовок ответа Location определяет безопасный URL-адрес для перенаправления.
Заголовок ответа Location определяет URL-адрес перенаправленияПроблема с этим подходом заключается в том, что злоумышленники могут перехватить сетевое соединение, чтобы перенаправить браузер на пользовательский URL-адрес. Подобные атаки типа «человек посередине» (MITM) довольно распространены. Популярный сериал даже подделывал его в одном из своих эпизодов.
Кроме того, злоумышленник может запустить атаку MITM без изменения URL-адреса, отображаемого в адресной строке браузера. Например, пользователю может быть предоставлена фишинговая страница, которая выглядит точно так же, как исходный сайт.
А поскольку все выглядит одинаково, включая URL-адрес в адресной строке, большинство пользователей с удовольствием введут свои учетные данные. Вы можете себе представить, почему это может быть плохо.
301 перенаправление на HTTPS небезопасноБезопасное перенаправление с HTTP 307 Внутреннее перенаправление
Теперь давайте попробуем тот же пример с Kinsta. Посещение http://kinsta.com приводит к сетевым запросам, как показано на скриншоте ниже.
Пример 307 Internal RedirectПервый запрос сайта аналогичен предыдущему примеру, но на этот раз он приводит к 307 Внутренний ответ перенаправления . Нажав на нее, вы увидите более подробную информацию об этом ответе.
Примечание: Если вы попытаетесь посетить сайт напрямую с https:// , вы не увидите этот заголовок, так как браузеру не нужно выполнять какое-либо перенаправление.
Заголовки ответа 307 Internal RedirectОбратите внимание на заголовок ответа Non-Authoritative-Reason: HSTS. Это строгая транспортная безопасность HTTP (HSTS), также известная как заголовок ответа Strict-Transport-Security.
Что такое HSTS (строгая транспортная безопасность)?
IETF ратифицировал HTTP Strict Transport Security (HSTS) в 2012 году, чтобы заставить браузеры использовать безопасные соединения, когда сайт работает строго по HTTPS.
Это похоже на то, как Chrome или Firefox говорят: «Я даже не буду пытаться запрашивать этот сайт или какие-либо его ресурсы по небезопасному протоколу HTTP. Вместо этого я поменяю его на HTTPS и попробую еще раз».
Вы можете следовать руководству Kinsta о том, как включить HSTS, чтобы запустить его на своем веб-сайте WordPress.
Улучшенная безопасность с ответом 307 Internal RedirectУглубление в заголовок ответа второго запроса даст нам лучшее понимание.
Проверка заголовка ответа HSTSЗдесь вы можете увидеть заголовок ответа strict-transport-security: max age=31536000.
Атрибут max-age заголовка ответа strict-transport-security определяет, как долго браузер должен следовать этому шаблону. В приведенном выше примере это значение равно 3153600 секунд (или 1 год).
Как только сайт вернет этот заголовок ответа, браузер даже не будет пытаться сделать обычный HTTP-запрос. Вместо этого он выполнит внутреннее перенаправление 307 на HTTPS и повторит попытку.
Каждый раз, когда этот процесс повторяется, заголовки ответов сбрасываются. Следовательно, браузер не сможет сделать небезопасный запрос в течение неопределенного периода времени.
Если вы размещаете свой сайт на Kinsta, вы можете создать заявку в службу поддержки, чтобы добавить заголовок HSTS на ваш сайт WordPress. Поскольку добавление заголовка HSTS дает преимущества в производительности, рекомендуется включить HSTS для вашего сайта.
Что такое список предварительной загрузки HSTS?
Даже с HSTS существует очевидная проблема с безопасностью. Самый первый HTTP-запрос, который вы отправляете с помощью браузера, небезопасен, что повторяет проблему, которую мы наблюдали ранее с Citibank.
Кроме того, заголовок ответа HSTS может быть отправлен только через HTTPS, поэтому первоначальный небезопасный запрос не может быть даже возвращен.
Для решения этой проблемы HSTS поддерживает атрибут предварительной загрузки в заголовке ответа. Идея состоит в том, чтобы иметь список сайтов, которые принудительно загружают HSTS в сам браузер, полностью обходя эту проблему безопасности.
Добавление вашего сайта в список предварительной загрузки HSTS браузера сообщит ему, что ваш сайт применяет строгую политику HSTS, даже если он посещает ваш сайт впервые. Затем браузер будет использовать ответ 307 Internal Redirect , чтобы перенаправить ваш сайт на безопасную схему https://, прежде чем запрашивать что-либо еще.
Обратите внимание, что в отличие от 307 Temporary Redirect , ответ 307 Internal Redirect является «фальшивым заголовком», установленным самим браузером. Он не исходит от сервера, веб-хостинга (например, Kinsta) или CMS (например, WordPress).
Добавление сайта в список предварительной загрузки HSTS имеет много преимуществ:
- Веб-сервер никогда не видит незащищенные HTTP-запросы. Это снижает нагрузку на сервер и делает сайт более безопасным.
- Браузер берет на себя перенаправление с HTTP на HTTPS, делая сайт более быстрым и безопасным.
Требования к списку предварительной загрузки HSTS
Если вы хотите добавить свой сайт в список предварительной загрузки HSTS браузера, необходимо отметить следующие условия:
- Для вашего домена должен быть установлен действующий сертификат SSL/TLS.
- Обеспечьте строгое соблюдение HTTPS, перенаправив весь HTTP-трафик на HTTPS.
- Все субдомены должны обслуживаться через HTTPS, особенно субдомен www , если существует запись DNS для этого субдомена.
- Ваш базовый домен должен включать заголовок HSTS со следующими атрибутами:
- Атрибут max-age должен быть установлен как минимум на 31536000 секунд (1 год).
- includeSubdomains и директивы preload должны быть указаны.
- Если вы обслуживаете дополнительное перенаправление, оно должно включать заголовок HSTS, а не страницу, на которую оно перенаправляется.
Добавление вашего сайта в список предварительной загрузки HSTS
Отправка списка предварительной загрузки HSTSСуществует два способа добавить ваш сайт в список предварительной загрузки HSTS.
- Отправив свой сайт в каталог списка предварительной загрузки HSTS. Например, главный список hstspreload.org поддерживается проектом с открытым исходным кодом Chromium и используется большинством основных браузеров (Firefox, Chrome, Safari, IE 11 и Edge).
- Добавив на свой сайт следующее поле заголовка:
Строгая транспортная безопасность: max-age=63072000; включать поддомены; preload
При использовании второго метода первое посещение вашего сайта браузером не будет полностью безопасным. Однако последующие посещения будут полностью безопасными.
Пример списка предварительной загрузки HSTS от MozillaВы можете использовать бесплатный онлайн-инструмент, такой как Security Headers, чтобы проверить, использует ли ваш сайт HSTS. Если вас беспокоит поддержка браузерами HSTS, вы можете быть уверены, зная, что HSTS поддерживается почти всеми используемыми сегодня браузерами.
HSTS пользуется широкой поддержкой во всех основных браузерахHTTP 307 Redirects и SEO
Поскольку ответ 307 Temporary Redirect показывает, что ресурс временно перемещен на новый URL-адрес, поисковые системы не обновляют свой индекс, чтобы включить этот новый URL-адрес. . «Ссылочный сок» из исходного URL-адреса не передается новому URL-адресу.
Это отличается от переадресации 301 Moved Permanently, когда поисковые системы обновляют свой индекс, чтобы включить новый URL-адрес и передать «ссылочный сок» с исходного URL-адреса на новый URL-адрес.
При ответе 307 Internal Redirect все происходит на уровне браузера. Следовательно, это не должно иметь прямого влияния на SEO вашего сайта. Однако добавление вашего сайта в список предварительной загрузки HSTS ускорит его загрузку и сделает его более безопасным, что может помочь ему занять более высокое место в результатах поиска.
Будьте осторожны, чтобы случайно не перенаправить пользователей и ботов в бесконечный цикл перенаправления, что приведет к ошибке «слишком много перенаправлений».
Существует множество типов кодов состояния перенаправления HTTP 3xx. Сегодня пришло время погрузиться в коды состояния временной переадресации HTTP 307… увидимся на другой стороне! 🛤Нажмите, чтобы твитнутьРезюме
Перенаправление URL-адресов позволяет назначить веб-странице более одного URL-адреса. Лучший способ обработки перенаправления URL-адресов — на уровне сервера с ответами кода состояния HTTP 3xx redirect . Если ваш сайт закрыт на техническое обслуживание или недоступен по другим причинам, вы можете временно перенаправить его на другой URL-адрес с ответом 307 Temporary Redirect .
При этом любое перенаправление увеличивает время загрузки страницы. Следовательно, используйте перенаправления разумно, всегда помня об опыте конечного пользователя.
Экономьте время, деньги и повышайте производительность сайта с помощью:
- Мгновенная помощь от экспертов по хостингу WordPress, круглосуточно и без выходных.
- Интеграция с Cloudflare Enterprise.
- Глобальный охват аудитории благодаря 35 центрам обработки данных по всему миру.
- Оптимизация с помощью нашего встроенного мониторинга производительности приложений.
Все это и многое другое в одном плане без долгосрочных контрактов, сопровождаемой миграции и 30-дневной гарантии возврата денег. Ознакомьтесь с нашими планами или поговорите с отделом продаж, чтобы найти план, который подходит именно вам.
F5 Cloud Docs
Расширяемость BIG-IP
- Расширение F5 Application Services 3
Конфигурации для конкретных приложений в системе BIG-IP с использованием декларативной модели.
- F5 Декларативное подключение
Начальная конфигурация системы BIG-IP с использованием декларативной модели.
- F5 Потоковая передача телеметрии
Агрегация, нормализация и пересылка статистики и событий из BIG-IP в потребительские приложения.
- Шаблоны служб приложений F5
Шаблоны
FAST предоставляют набор инструментов для создания шаблонов и управления приложениями AS3 на BIG-IP
.
- F5 Отказоустойчивое облако
Функциональность аварийного переключения L3 для системы BIG-IP в облачных средах.
- iApps LX/iControl LX
Возможность программирования уровня управления системой BIG-IP или платформой iWorkflow с помощью Node.js.
- F5 Управляемая конфигурация доступа BIG-IP
Управляемая настройка с использованием REST API, коннектора SAML IdP и конфигурации приложения SaaS.
Руководства на GitHub
- Декларативная политика F5 BIG-IP WAF
Специальные конфигурации WAF в системе BIG-IP с использованием модели декларативной политики.
Облачные интеграции
- Облачные службы F5
Облачные решения SaaS для улучшенной доставки приложений, безопасности и анализа.
- Распределенная облачная платформа F5
F5 Эталонные архитектуры распределенного облака и соответствующая информация о реализации.
- BIG-IP ВЭ
BIG-IP Virtual Edition (VE) на общедоступных и частных облачных платформах.
- OpenStack Китай
решения OpenStack для рынка Китая.
Интеграция экосистем
- Модули F5 для Ansible
Набор модулей Ansible для системы BIG-IP.
Модули на GitHub
- Ресурсы F5 для Terraform Provider
Набор ресурсов F5 для Terraform.
- Сервисный центр F5 ACI
Интеграция между BIG-IP и инфраструктурой, ориентированной на приложения Cisco (ACI).
- Интеграция контейнеров Kubernetes
Встроенная интеграция BIG-IP в Kubernetes с F5 Container Ingress Services.
- Интеграция контейнера RedHat OpenShift
Встроенная интеграция BIG-IP как в RedHat OpenShift, так и в OpenShift Origin с F5 Container Ingress Services.
Сети 5G
- Прокси службы для Kubernetes
Облачное решение для управления трафиком приложений, разработанное для сетей CoSP 5G.
- Облачные сетевые функции
Передовые решения для обеспечения безопасности и управления трафиком для облачных сетей CoSP 5G.
Справочник по API
- F5 BIG-IQ API
REST API для сценариев рабочих процессов BIG-IQ.
- F5 BIG-IP iApps
настраиваемых инструмента настройки на основе шаблонов для развертывания служб приложений.
- F5 BIG-IP iRules API
API программирования на основе Tcl для трафика плоскости данных.
- F5 BIG-IP iRulesLX API
API программирования на основе Node. js для трафика плоскости данных.
- F5 BIG-IP iControlREST API
API на основе REST для императивной настройки и управления услугами BIG-IP.
- API iControl F5 BIG-IP
API на основе SOAP для императивной настройки и управления услугами BIG-IP.
- F5 iHealth API
API на основе REST для программной работы с диагностическим сайтом F5 iHealth.
- API скриптов F5 tmsh
API сценариев на основе Tcl для действий плоскости управления в BIG-IP.
Благодарности OSS
Справочник интерфейса командной строки
- F5 Справочник TMSH
Ссылки
TMSH представляют собой наборы версий справочных страниц BIG-IP tmsh.
- F5OS-C/ВЕЛОС CLI
Интерфейс командной строки для настройки F5OS в системах VELOS.
- Интерфейс командной строки F5OS-A/F5 rSeries
Интерфейс командной строки для настройки F5OS в системах rSeries.
Виртуализация сетевых функций
F5 SSL Visibility
- F5 SSL Orchestrator
Обеспечивает видимость зашифрованного трафика SSL/TLS с управлением трафиком и динамической цепочкой сервисов
- Руководство по устранению неполадок SSLO
Руководство на основе блок-схем по устранению распространенных проблем в F5 SSL Orchestrator
Обучение и лаборатории
Узнайте, как получить максимальную отдачу от продуктов F5 с помощью онлайн-обучения и лабораторных материалов.
Посетите сообщество F5 Training and Labs- Автоматизированная песочница F5
Предоставление инфраструктуры и выполнение вариантов использования с использованием шаблонов
- Решения доступа F5
Предоставляет автоматизированные примеры конфигурации APM для решения распространенных вариантов использования
Варианты использования - SPK
Обзор вариантов использования Service Proxy для Kubernetes
next.
config.js: перенаправления | Next.js Примеры- Перенаправления Добавлено
v9.5.0
Добавлены редиректы. Перенаправления позволяют вам перенаправить путь входящего запроса на другой путь назначения.
Чтобы использовать перенаправления, вы можете использовать ключ
перенаправлений
вnext.config.js
:module.exports = { асинхронные перенаправления () { возвращаться [ { источник: '/о', назначения: '/', постоянный: правда, }, ] }, }
перенаправляет
— это асинхронная функция, которая ожидает возврата массива, содержащего объекты систочником
,назначением
ипостоянными
свойствами:-
источник
— шаблон пути входящего запроса. -
пункт назначения
— это путь, по которому вы хотите выполнить маршрут. -
постоянная
истина
илиложь
— еслиистина
будет использовать код состояния 308, который указывает клиентам/поисковым системам навсегда кэшировать перенаправление, еслиложь
будет использовать код состояния 307, который является временным и не является кэшировано.
Почему Next.js использует 307 и 308? Традиционно код 302 использовался для временного перенаправления, а код 301 — для постоянного перенаправления, но многие браузеры изменили метод запроса перенаправления на
GET
независимо от исходного метода. Например, если браузер сделал запросPOST /v1/users
, который вернул код состояния302
с местоположением/v2/users
, последующий запрос может бытьGET /v2/users
вместо ожидаемого. ПОСТ /v2/пользователи
. Next.js использует коды состояния временного перенаправления 307 и постоянного перенаправления 308, чтобы явно сохранить используемый метод запроса.-
basePath
:false
илиundefined
— если false, basePath не будет включен при сопоставлении, может использоваться только для внешних перезаписей. -
локаль
:false
илиundefined
— не следует ли включать локаль при сопоставлении. -
has
представляет собой массив объектов has со свойствами типаkey
иvalue
.
Перенаправления проверяются перед файловой системой, которая включает страницы и
/public
файлов.При применении перенаправления любые значения запроса, предоставленные в запросе, будут переданы в пункт назначения перенаправления. Например, см. следующую конфигурацию перенаправления:
{ источник: '/старый-блог/:путь*', пункт назначения: '/блог/:путь*', постоянный: ложный }
При запросе
/old-blog/post-1?hello=world
клиент будет перенаправлен на/blog/post-1?hello=world
.Допускаются совпадения путей, например
/old-blog/:slug
будет соответствовать/old-blog/hello-world
(без вложенных путей):module.exports = { асинхронные перенаправления () { возвращаться [ { источник: '/old-blog/:slug', назначение: '/news/:slug', // Соответствующие параметры могут использоваться в назначении постоянный: правда, }, ] }, }
Сопоставление пути с подстановочным знаком
Для сопоставления пути с подстановочным знаком вы можете использовать
*
после параметра, например/blog/:slug*
будет соответствовать/blog/a/b/c/d/hello-world
:module.exports = { асинхронные перенаправления () { возвращаться [ { источник: '/блог/:слаг*', назначение: '/news/:slug*', // Соответствующие параметры могут использоваться в назначении постоянный: правда, }, ] }, }
Сопоставление пути регулярного выражения
Для сопоставления пути регулярного выражения вы можете заключить регулярное выражение в круглые скобки после параметра, например,
/post/:slug(\\d{1,})
будет соответствовать/post/123
, но не/post/abc
:module. exports = { асинхронные перенаправления () { возвращаться [ { источник: '/post/:slug(\\d{1,})', назначение: '/news/:slug', // Соответствующие параметры могут использоваться в назначении постоянный: ложный, }, ] }, }
Следующие символы
(
,)
,{
,}
,:
,*
,+
8 , ? используются для сопоставления путей регулярных выражений, поэтому при использовании висточник
как неспециальные значения их необходимо экранировать, добавив перед ними\
:module.exports = { асинхронные перенаправления () { возвращаться [ { // это будет соответствовать запрашиваемому `/english(default)/something` источник: '/english\\(по умолчанию\\)/:slug', пункт назначения: '/en-us/:slug', постоянный: ложный, }, ] }, }
Чтобы соответствовать перенаправлению только тогда, когда значения заголовка, файла cookie или запроса также совпадают, можно использовать поле
has
. Обаисточник
и всеимеют
элементов должны совпадать для применения перенаправления.содержит элементы
со следующими полями:-
type
:String
— должен быть заголовокcookie
,хост , 8 .
-
ключ
:Строка
- ключ выбранного типа для сопоставления. -
значение
:Строка
илине определено
- значение для проверки, если не определено любое значение будет соответствовать. Строка, подобная регулярному выражению, может использоваться для захвата определенной части значения, например. если значениеfirst-(?
используется для.*) first-second
, тоsecond
можно будет использовать в пункте назначения с:paramName
.
модуль.экспорт = { асинхронные перенаправления () { возвращаться [ // если присутствует заголовок `x-redirect-me`, // это перенаправление будет применено { источник: '/:путь((?!другая-страница$). *)', имеет: [ { тип: 'заголовок', ключ: 'x-перенаправить меня', }, ], постоянный: ложный, пункт назначения: '/другая-страница', }, // если источник, запрос и файл cookie совпадают, // это перенаправление будет применено { источник: '/специфический/:путь*', имеет: [ { тип: 'запрос', ключ: "страница", // значение страницы не будет доступно в // место назначения, так как значение предоставлено и не // использовать именованную группу захвата, например. (?
домой) значение: «дом», }, { тип: 'куки', ключ: «авторизованный», значение: «истина», }, ], постоянный: ложный, пункт назначения: '/другой/:путь*', }, // если заголовок `x-authorized` присутствует и // содержит совпадающее значение, будет применено это перенаправление { источник: '/', имеет: [ { тип: 'заголовок', ключ: «x-авторизованный», значение: '(?<авторизованный>да|истина)', }, ], постоянный: ложный, пункт назначения: '/home?authorized=:authorized', }, // если хост `example. com`, // это перенаправление будет применено { источник: '/:путь((?!другая-страница$).*)', имеет: [ { тип: «хост», значение: 'example.com', }, ], постоянный: ложный, пункт назначения: '/другая-страница', }, ] }, } Перенаправления с поддержкой basePath
При использовании поддержки
basePath
с перенаправлениями каждыйисточник
ипункт назначения
автоматически имеют префиксbasePath
, если вы не добавитеbasePath module = 90exports 90 90 redirect 90 redirect 90. { базовый путь: '/ документы', асинхронные перенаправления () { возвращаться [ { источник: '/with-basePath', // автоматически становится /docs/with-basePath назначение: '/another', // автоматически становится /docs/another постоянный: ложный, }, { // не добавляет /docs, так как basePath: false установлен источник: '/без-basePath', пункт назначения: '/другой', базовый путь: ложь, постоянный: ложный, }, ] }, }
Перенаправления с поддержкой i18n
При использовании
поддержки i18n
с перенаправлениями каждомуисточнику
иместу назначения
автоматически присваивается префикс для обработки настроенных локалейлокали для перенаправления
: false Если используется локаль: false
, вы должны добавить префиксисточника
иназначения
с локалью, чтобы они сопоставлялись правильно.модуль.экспорт = { i18n: { локали: ['en', 'fr', 'de'], язык по умолчанию: 'en', }, асинхронные перенаправления () { возвращаться [ { source: '/with-locale', // автоматически обрабатывает все локали назначение: '/another', // автоматически передает локаль на постоянный: ложный, }, { // не обрабатывает локали автоматически, поскольку установлено значение locale: false источник: '/nl/with-locale-manual', пункт назначения: '/nl/другой', локаль: ложь, постоянный: ложный, }, { // это соответствует '/', так как `en` является языком по умолчанию источник: '/ru', пункт назначения: '/en/other', локаль: ложь, постоянный: ложный, }, // можно сопоставить все локали, даже если установлена локаль: false { источник: '/:локаль/страница', пункт назначения: '/en/newpage', постоянный: ложный, локаль: ложь, } { // это преобразуется в /(en|fr|de)/(. *), поэтому не будет соответствовать верхнему уровню // Маршруты `/` или `/fr`, такие как /:path*, источник: '/(.*)', пункт назначения: '/другой', постоянный: ложный, }, ] }, }
В некоторых редких случаях вам может потребоваться назначить пользовательский код состояния для более старых HTTP-клиентов для правильного перенаправления. В этих случаях можно использовать свойство
statusCode
вместо постоянного свойстваRefresh
автоматически добавляется к коду состояния 308.- Внутри маршрутов API вы можете использовать
res.redirect()
. - Внутри
getStaticProps
иgetServerSideProps
, вы можете перенаправить определенные страницы во время запроса.
Типы перенаправлений URL и передовой опыт поисковой оптимизации
Вы когда-нибудь посещали веб-страницу, которая перенаправляла вас на другую страницу, которую вы не искали? Или, может быть, вы получили сообщение «Извините, недоступно»? Что ж, ты не одинок, мой друг. Необоснованные ошибки URL встречаются чаще, чем вы думаете. К счастью, есть передовые методы SEO, которые вы можете использовать для перенаправления URL-адресов, которые позволят вам бороться с этими досадными ошибками.
В этом посте я расскажу, что такое перенаправления, почему они важны, наиболее распространенные типы перенаправлений, их влияние на SEO и рекомендации по использованию URL. Важно понимать, как и когда правильно использовать перенаправления, поскольку они могут улучшить взаимодействие с пользователем и помочь сайту ранжироваться с точки зрения SEO.
Что такое перенаправление URL?
Перенаправление URL — это метод, используемый для перенаправления пользователей со старого или, возможно, уже не существующего URL-адреса на другой URL-адрес, который активен и работает должным образом.
Например, предположим, что на ювелирном веб-сайте есть устаревшая страница https://www.jewerly.com/silverearrings (URL A), которую они больше не хотят, чтобы пользователи посещали. Они могут использовать код перенаправления 301 для постоянного перенаправления URL-адреса A на новую страницу с обновленным контентом «https://www.jewerly.com/goldearrings» (URL-адрес B). Теперь, если пользователь щелкнет URL-адрес A, он будет автоматически перенаправлен на URL-адрес B и увидит обновленный контент.
301 Графика перенаправления URL-адресов от Granite5Перенаправления используются для временной переадресации трафика во время обслуживания сервера, перемещения веб-сайта на новый домен, объединения дублированного контента и перемещения посетителей веб-сайта со старого контента на новый контент. Существует множество различных типов кодов перенаправления, поэтому чрезвычайно важно знать различия между каждым типом и когда их использовать.
Типы перенаправлений URL
Существует множество типов перенаправлений, которые вы можете использовать. В этом разделе я сосредоточусь на наиболее часто используемых переадресациях: 301, 302 и 307, поскольку 308 используется редко. 404 не идеальны, поэтому я коснусь их в разделе лучших практик. Хотя на первый взгляд большинство используемых переадресаций могут показаться похожими, эти уникальные коды переадресации весьма важны для SEO-специалистов и должны использоваться правильно. Выбирая, какой код перенаправления использовать, вы должны определить, какой тип будет наиболее эффективным для вашей конкретной цели.
301 URL-адрес перенаправления
URL-адрес перенаправления 301 используется, когда страница окончательно удаляется или удаляется с веб-сайта. Это наиболее распространенный и чистый код перенаправления. Код 301 используется для сохранения трафика, рейтинга и обратных ссылок.
Перенаправление 301 в конечном итоге будет проиндексировано поисковыми системами, которые включают его новый контент, и считается наиболее эффективным и удобным для поисковых систем методом перенаправления. Этот метод требует от поисковых систем от нескольких недель до месяцев, чтобы проиндексировать перенаправленную страницу. 301 редиректы не вредны. На самом деле, при правильном использовании они действительно полезны, поскольку новая страница будет иметь тот же авторитет страницы, что и исходная.
Используйте URL-адрес перенаправления 301, когда:
- Исправление неработающих обратных ссылок (404)
- Разрешение дублированного контента
- Объединение двух веб-сайтов и вы хотите перенаправить пользователей на правильные страницы
- 90main
- Создание нового поддополнения Выбор правильного канонического URL-адреса
302 URL-адрес перенаправления
URL-адрес перенаправления 302 используется, когда страница временно перемещается на другой URL-адрес. Этот код перенаправления не передает никаких прав доступа к странице со старого URL-адреса на новый URL-адрес, поскольку он не является постоянным. Поисковые системы по-прежнему смогут индексировать исходный URL и поддерживать его рейтинг. Важно знать цель вашего перенаправления, потому что, если вы перепутаете, какой код перенаправления вы используете, вы можете получить эффект, противоположный тому, который вы хотели.
Допустим, вы продвигаете новый продукт (страница Б) и хотите временно направить пользователей на эту страницу. Google знает, что это временно, и не удалит исходную страницу (страницу А) из результатов поиска или обесценит ее рейтинг. Но если вы случайно используете переадресацию 301 вместо переадресации 302, исходная страница (Страница А) потеряет рейтинг и может быть деиндексирована поисковыми системами.
Используйте URL-адрес перенаправления 302, когда:
- Работа по обслуживанию веб-сайта
- Страница специальных акций
- A/B-тестирование
- Перенаправление посетителей с мобильных устройств на рабочий стол и наоборот
307 URL-адрес перенаправления
URL-адрес перенаправления 307 или HTTP 307 Temporary Redirect очень похож на код перенаправления 302. Оба они временные и используются для аналогичных целей. Однако код 307 — это перенаправление на стороне сервера, специально используемое для HTTP. Этот метод кода URL-адреса перенаправления используется, чтобы гарантировать, что HTTP-запрос не изменится, когда сервер ответит перенаправлением. Код переадресации 307 не оказывает большого влияния на SEO.
Вместо перенаправления 307 рекомендуется использовать код перенаправления 302.
Как переадресация URL влияет на SEO?
Google положительно относится к редиректам. В предыдущие годы SEO-специалисты были обеспокоены тем, что слишком много перенаправлений веб-сайтов приведет к падению рейтинга поисковых систем. Но текущая позиция Google подтверждает, что редиректы 301, 302 и 307 при правильном использовании не оказывают вредного влияния на SEO. На самом деле перенаправления могут помочь плавно перенести домены и обновить структуры постоянных ссылок.
Кроме того, Google поясняет, что «301 или 302 редиректы не приводят к потере PageRank». Это означает, что когда вы используете перенаправление URL-адреса 301, поисковые системы передают авторитет страницы с исходного URL-адреса на новый URL-адрес, не нанося вреда вашему SEO.
При правильном выполнении перенаправления не повредят вашему поисковому рейтингу. Но если они плохо выполнены, перенаправления могут снизить ваш SEO-рейтинг. Поэтому важно знать, какие перенаправления использовать для веб-сайта, чтобы избежать негативного влияния на производительность вашего сайта.
Рисунок перенаправления URL-адресов из J-26Перенаправления доменов
При переносе сайта лучшим способом перенаправления доменов должен быть код перенаправления 301 на основной домен. Этот метод используется, потому что перенаправление 301 является постоянным. Лучше всего указать код перенаправления 301 для каждого домена, который имеет www, не-www, HTTP и HTTPS. Google считает, что основным доменом является HTTPS. После перенаправления всегда проверяйте, проиндексирован ли новый домен. Вы можете использовать такие инструменты, как инструмент проверки URL-адресов Google.
Лучшие практики для перенаправления URL-адресов
Ниже я поделюсь шестью лучшими практиками для перенаправления URL-адресов. Следуйте этим советам, чтобы сталкиваться с меньшим количеством проблем с переадресацией. Помните, чем больше внимания вы уделяете внедрению правильных методов перенаправления URL-адресов, тем менее хаотичным будет ваш сайт.
1. Перенаправление на наиболее релевантные и похожие страницы
Для перенаправления URL-адресов передового опыта SEO попробуйте перенаправить на наиболее релевантные и похожие страницы. Перенаправление на страницы, предназначение которых полностью отличается от исходного, считается плохой практикой, и его следует избегать любой ценой.
2. Избегайте цепочек перенаправления
Цепочки перенаправления — распространенная ошибка, и важно их избегать. Пользователь может не видеть множество скачков цепочки перенаправлений, но Google это замечает. Хороший инструмент для обнаружения цепочек редиректов — Screaming Frog. После пяти перенаправлений Google прекратит сканирование, в результате чего новый URL никогда не будет отображаться.
Графика цепочки перенаправлений от Ahrefs3.
Обновление внутренних ссылокУбедитесь, что внутренние ссылки всегда обновляются. Внутренние ссылки должны быть точными, иначе это может привести к значительному замедлению работы веб-сайта. Важно свести к минимуму количество переадресаций на веб-сайте. Уделите приоритетное внимание очистке перенаправлений, чтобы сохранить авторитет SEO и уменьшить влияние на сканирование Googlebot. Вы никогда не знаете, когда старые перенаправления могут вызвать неразрешимое поведение на веб-сайте.
4. Избегайте метатегов обновления
Держитесь подальше от метатегов обновления. Мета-теги обновления содержат сообщение на странице с обратным отсчетом в секундах, которое обычно гласит: «Если вас не перенаправят в течение 10 секунд, нажмите здесь». и загрузит другой URL. Этот метод не только является спамом, но и подталкивает пользователей к страницам с другим содержанием, чем то, что они изначально искали. Эти перенаправления вредны для пользователей и определенно не рекомендуются для SEO.
Пример метатега обновления с сайта CloudFare.com5. Избегайте мягких 404
Избегайте мягких 404. Google будет рассматривать перенаправление на нерелевантную страницу как мягкую ошибку 404. Это означает, что Google будет игнорировать перенаправление и не будет передавать полномочия страницы. Например, если на странице была реклама обуви, а распродажа только что закончилась, эта ссылка должна быть перенаправлена на URL-адрес с похожим товаром, а не на страницу с автомобилями.
6. Используйте 404 экономно и проявляйте творческий подход
Иногда можно использовать 404. Иногда необходимо оставить страницу с ошибкой 404, особенно если на новом сайте нет эквивалентной страницы. Когда они у вас есть, неплохо создать пользовательскую страницу 404 с контактной информацией или полезными ссылками, которые могут принести пользу пользователю. Этот метод направит пользователя к тому, что он ищет, и удержит его на вашем сайте.
Пример хорошо оформленной страницы 404 от Pixar, размещенной в блоге службы поддержки WordPressЗаключительные мысли
Последовательность — это ключ! Хотя правильная реализация переадресации URL-адресов может занять много времени, особенно если на вашем веб-сайте тысячи переадресаций, в долгосрочной перспективе стоит потратить время и сделать это правильно с первого раза.