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

Как правильно обрабатывать относительные URL-адреса с помощью обратного прокси

У меня в Apache настроен обратный прокси:

Сервер A с адресом www.example.com/folder является обратным прокси-сервером.

Он отображается на: Сервер B с адресом test.madeupurl.com

Такого рода работы. Но у меня проблема в том, что на www.example.com/folder все относительные ссылки имеют форму www.example.com/css/examplefilename.css, а не www.example.com/folder/css/examplefilename. css

Как это исправить?

Пока что у моего обратного прокси на сервере A (www.example.com) это есть:

<Location /folder>
    ProxyPass  http://test.madeupurl.com
    ProxyPassReverse http://test.madeupurl.com
</Location>

Apache ProxyPassRewrite не перезаписывает тела ответа, полученные от http://test.example.com, только заголовки (например, перенаправления на страницу 404 и т.п.).

Ряд альтернатив:

Один) Перепишите внутреннее приложение, чтобы использовать относительные пути вместо абсолютных. т.е. ../css/style.css вместо того /css/style.css

Два) Повторно разверните внутреннее приложение в том же подкаталоге /folder а не в корне test.example.com.

Три) Один и два часто маловероятны ... Если вам повезет, внутреннее приложение использует только два или три подкаталога и они не используются на вашем основном сайте, просто напишите несколько строк ProxyPass:

# Expose Internal App to the internet.
ProxyPass /externalpath/  http://test.example.com/
ProxyPassReverse /externalpath/  http://test.example.com/
# Internal app uses a bunch of absolute paths. 
ProxyPass /css/  http://test.example.com/css/
ProxyPassReverse /css/  http://test.example.com/css/
ProxyPass /icons/  http://test.example.com/icons/
ProxyPassReverse /icons/  http://test.example.com/icons/

Четыре) Создайте отдельный поддомен для внутреннего приложения и просто отмените все прокси:

<VirtualHost *:80>
   ServerName app.example.com/
   # Expose Internal App to the internet.
   ProxyPass /  http://test.internal.example.com/
   ProxyPassReverse /  http://test.internal.example.com/
</VirtualHost>

Пять) Иногда разработчики совершенно невежественны и их приложения не только генерируют абсолютные URL-адреса, но даже включают часть имени хоста в свои URL-адреса, и результирующий HTML-код выглядит следующим образом: <img src=http://test.example.com/icons/logo.png>.

АВы можете использовать комбинированное решение DNS с разделением горизонта и сценария 4. И внутренние, и внешние пользователи используют test.example.com, но ваш внутренний DNS указывает непосредственно на IP-адрес сервера test.example.com. Для внешних пользователей общедоступная запись для test.example.com указывает на IP-адрес вашего общедоступного веб-сервера www.example.com, и вы можете использовать решение 4.

BВы действительно можете получить apache не только для прокси-запросов к test.example.com, но и для переписать тело ответа прежде, чем он будет передан вашим пользователям. (Обычно прокси перезаписывает только заголовки / ответы HTTP). mod_substitute в apache 2.2. Я не проверял, хорошо ли он сочетается с mod_proxy, но, возможно, работает следующее:

<Location /folder/>
  ProxyPass http://test.example.com/
  ProxyPassReverse http://test.example.com/ 
  AddOutputFilterByType SUBSTITUTE text/html
  Substitute "s|test.example.com/|www.example.com/folder/|i" 
</Location>

В дополнение к HBruijnответ, если вы выберете решение (3) "ProxyPass", возможно, вам также придется использовать mod_proxy_html переписать некоторые URL-адреса на ваших HTML-страницах.

ср. Как правильно обрабатывать относительные URL-адреса с помощью обратного прокси для некоторых примеров.

В качестве прикладного примера вот как вы можете настроить Apache с помощью ProxyHTMLURLMap Правило пересылать все на your-domain-name.com/pad на ваш Etherpad экземпляр, работающий локально на порту 9001:

<Location /pad> ProxyPass http://localhost:9001 retry=0 # retry=0 => avoid 503's when restarting etherpad-lite ProxyPassReverse http://localhost:9001 SetOutputFilter proxy-html ProxyHTMLURLMap http://localhost:9001 </Location> RewriteRule ^/pad$ /pad/ [R]

Вы можете использовать следующий способ сделать обратный прокси:
1. Установите mod_proxy_html

    yum install mod_proxy_html
  1. Загрузите модуль mod_proxy_html

    LoadModule proxy_html_module modules/mod_proxy_html.so
    
  2. И используйте следующую настройку

    ProxyRequests off  
    ProxyPass /folder/  http://test.madeupurl.com  
    ProxyHTMLURLMap http://test.madeupurl.com  /folder  
    
    <Location /folder/>  
        ProxyPassReverse /  
        ProxyHTMLEnable On  
        ProxyHTMLURLMap  /  /folder/  
        RequestHeader    unset  Accept-Encoding  
    </Location>  
    

Надеюсь на эту помощь.