Ваш вопрос немного расплывчат, поскольку вы пишете о двух разных вещах.Вот два подхода, которые, мы надеемся, укажут вам правильное направление:
Чтобы перенаправить любой запрос на "domain2.com" на эту "целевую страницу", это, вероятно, то, что вы ищете:
RewriteEngine on
RewriteCond %{HTTP_HOST} ^domain2\.com$
RewriteCond %{REQUEST_URI} !^/domain-2-landing$
RewriteRule ^ /domain-2-landing [R=301]
Хорошей идеей будет начать с временного перенаправления 302 и изменить его на постоянное перенаправление 301 позже, как только вы убедитесь, что все настроено правильно.Это предотвращает проблемы с кешированием при испытаниях ...
Чтобы доставить содержимое этой страницы в ответ на запросы "domain.com", существует две разные ситуации:
Если доменыобслуживаются с отдельных http-серверов, вы можете использовать функцию прокси, встроенную в модуль перезаписи , если установлен прокси-модуль:
RewriteEngine on
RewriteCond %{HTTP_HOST} ^domain\.com$
RewriteRule ^ https://domain2.com/domain-2-landing [P,END]
Если оба домена обслуживаются с одного http-сервера, выможет сделать что-то подобное, как указано выше, , если оба хоста совместно используют один и тот же DOCUMENT_ROOT
:
RewriteEngine on
RewriteCond %{HTTP_HOST} ^domain\.com$
RewriteRule ^ /domain-2-landing [END]
В случае, если вы получаете внутреннюю ошибку сервера (http status 500), используя приведенное выше правило, тогдаСкорее всего, вы используете очень старую версию HTTP-сервера Apache.В этом случае вы увидите определенный намек на неподдерживаемый флаг [END]
в файле журнала ошибок http-серверов.Вы можете попробовать обновить или использовать более старый флаг [L]
, он, вероятно, будет работать так же в этой ситуации, хотя это немного зависит от ваших настроек.
Эти правила также будут работать в конфигурации хоста http-серверов или внутри файла динамической конфигурации (файл ".htaccess").Очевидно, что модуль перезаписи должен быть загружен внутри http-сервера и включен на хосте http.Если вы используете динамический файл конфигурации, вам нужно позаботиться о том, чтобы его интерпретация была включена вообще в конфигурации хоста и чтобы он находился в папке DOCUMENT_ROOT
хоста.
И общее замечание: вы всегда должны предпочитать размещать такие правила в конфигурации хоста http-серверов вместо использования файлов динамической конфигурации (".htaccess").Эти динамические файлы конфигурации добавляют сложность, часто являются причиной неожиданного поведения, их трудно отладить, и они действительно замедляют работу http-сервера.Они предоставляются только в качестве последнего варианта для ситуаций, когда у вас нет доступа к реальной конфигурации хоста http-серверов (читай: действительно дешевые поставщики услуг) или для приложений, настаивающих на написании своих собственных правил (что является очевидным кошмаром безопасности).