Я бы также настоятельно рекомендовал бы использовать виртуальные хосты для такой настройки. Но ваш конкретный c вопрос касается динамического переписывания c для сопоставления запрошенных имен хостов (называемых в вашем вопросе «доменами») с папками. Это должно указать вам правильное направление:
RewriteEngine on
RequestCond %{REQUST_URI} !^/public/
RewriteRule ^ /public/%{HTTP_HOST}%{REQUEST_URI} [QSA,END]
Вы также можете добавить тест для папки, который позволил бы создать специальный документ об ошибке:
RewriteEngine on
RequestCond /public/%{HTTP_HOST} !-d
RewriteRule ^ /error_host_not_found.php
RequestCond %{REQUST_URI} !^/public/
RewriteRule ^ /public/%{HTTP_HOST}%{REQUEST_URI} [QSA,END]
В случае, если вы получаете внутреннюю ошибку сервера (http status 500), используя приведенное выше правило, скорее всего, вы используете очень старую версию apache http-сервера. В этом случае вы увидите определенный намек на неподдерживаемый флаг [END]
в файле журнала ошибок http-серверов. Вы можете попробовать обновить или использовать более старый флаг [L]
, он, вероятно, будет работать так же в этой ситуации, хотя это немного зависит от ваших настроек.
Эта реализация также будет работать в конфигурации хоста http-серверов или внутри распределенного файла конфигурации (файл ".htaccess"). Очевидно, что модуль перезаписи должен быть загружен внутри http-сервера и включен на хосте http. Если вы используете распределенный файл конфигурации, вам нужно позаботиться о том, чтобы его интерпретация вообще была включена в конфигурации хоста и находилась в папке DOCUMENT_ROOT
хоста.
И общее замечание: вы всегда должны предпочитать размещать такие правила в конфигурации хоста http-серверов вместо использования распределенных файлов конфигурации (".htaccess"). Эти распределенные файлы конфигурации добавляют сложность, часто являются причиной неожиданного поведения, их трудно отладить, и они действительно замедляют работу http-сервера. Они предоставляются только в качестве последнего варианта для ситуаций, когда у вас нет доступа к реальной конфигурации хоста http-серверов (читай: действительно дешевые поставщики услуг) или для приложений, настаивающих на написании своих собственных правил (что является очевидным кошмаром безопасности).