Как маскировать поддомен с помощью nginx

#nginx #url-rewriting #nginx-reverse-proxy #nginx-config

Вопрос:

У меня есть приложение nodejs, работающее с основным доменом, и его прокси-сервер nginx , подключенный к приложению nodejs, с правилом перенаправления, в соответствии с правилом перенаправления, если запрос поступает с мобильного, он перенаправится в поддомен, он работает нормально.

как основной домен ,так и поддомен имеют разные версии и работают на разных серверах.

Теперь я хочу замаскировать этот поддомен , я не хочу видеть свой поддомен в браузере, как я могу это сделать.

Ниже упоминается моя конф. nginx.

 server {
        listen         80;
        server_name    mydomain;
        return         301 https://$server_name$request_uri;
}
include mime.types;
server {
        listen 443 ssl;
    server_name mydomain;
        ssl_certificate /etc/ssl/CA_Bundle.ca-bundle;
        ssl_certificate_key /etc/ssl/2021/server.key;
    location / {
                add_header Access-Control-Allow-Origin *;
                proxy_set_header Host $host;
                proxy_pass http://172.17.0.1:8080;
                proxy_redirect off;
                expires off;

      set $agentflag 0;

      if ( $http_user_agent ~* "(Mobile)" ){
                set $agentflag 1;
      }

      if ($request_uri ~ "user-agent"){
              set $agentflag 0;
      }


      if ( $agentflag = 1 ) {
              rewrite ^/(.*)/$ /$1 permanent;
              return 307 https://mobile.mydomain$request_uri;
      }
        }
}


server {
        listen         80;
        server_name    mobile.mydomain;
        return         301 https://$server_name$request_uri;
}
include mime.types;
server {
        listen 443 ssl;
    server_name mobile.mydomain;
        ssl_certificate /etc/ssl/CA_Bundle.ca-bundle;
        ssl_certificate_key /etc/ssl/2021/server.key;
    location / {
                add_header Access-Control-Allow-Origin *;
                proxy_set_header Host $host;
                proxy_pass http://172.17.22.1:8081;
                proxy_redirect off;
                expires off;
    }
}
 

Ответ №1:

Сейчас он работает нормально,

Я использовал proxy_pass вместо перезаписи.

   if ( $agentflag = 1 ) {
          proxy_pass http://IP-address-mobile-app;