是否在nginx上重写丛媒体服务器url?

是否在nginx上重写丛媒体服务器url?,nginx,rewrite,Nginx,Rewrite,我对在nginx中重写url的知识非常有限。我在nginx上有一台plex媒体服务器,我可以使用在github上找到的以下配置访问仪表板: upstream plex-upstream { server plex-server.example.com:32400; } server { listen 80; server_name domain.com location / { if ($http_x_plex_device_name = ''

我对在nginx中重写url的知识非常有限。我在nginx上有一台plex媒体服务器,我可以使用在github上找到的以下配置访问仪表板:

upstream plex-upstream {
    server plex-server.example.com:32400;
}

server {
listen 80;
server_name domain.com

    location / {
                if ($http_x_plex_device_name = '') {
                      rewrite ^/$ http://$http_host/web/index.html;
}

            proxy_set_header X-Real-IP $remote_addr;
                proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
                proxy_redirect off;

                proxy_set_header Host $http_host;
            proxy_pass http://plex-upstream;
}
}

我想要的是删除/web/index.html,这样当我转到时,PMS仪表板将加载。我已经尝试了一些单行重写规则,但都失败了。谢谢。

我不是nginx专家,但我也有类似的问题。 区别在于我没有尝试将domain.name/别名为domain.name/web/, 我的目标是将domain.name/plex/别名为domain.name/web/。 我得到了指向web/index.html的重定向,其中包括除此之外我能找到的所有解决方案

唯一的一个问题是,如果你去网络/你会留在那里

下面是我令人毛骨悚然但行之有效的解决方案:

upstream plex {
    server localhost:32400;
}

server {
    listen 80;
    server_name domain.name;
    server_name_in_redirect off;

    location / {
        proxy_pass http://localhost:8888;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header Host $http_host;
        proxy_set_header X-NginX-Proxy true;

        # Enables WS support
        proxy_http_version 1.1;
        proxy_set_header Upgrade $http_upgrade;
        proxy_set_header Connection "upgrade";
        proxy_redirect off;
    }

    location /web/index.html {
      if ($http_x_should_not_redirect = ""){
        return 301 https://domain.name/plex/index.html;
      }

      proxy_pass https://plex;
      proxy_set_header Host $host;
      proxy_set_header X-Real-IP $remote_addr;
      proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
      proxy_set_header x_should_not_redirect $host;
    }

    location /web {
      proxy_pass https://plex;
      proxy_set_header Host $host;
      proxy_set_header X-Real-IP $remote_addr;
      proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
      proxy_set_header x_should_not_redirect $host;
    }

    location /plex {
      proxy_pass https://127.0.0.1/web;
      proxy_set_header X-should-not-redirect $host; 
    }



    location /transmission/rpc {
        proxy_pass http://localhost:9091;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header Host $http_host;
        proxy_set_header X-NginX-Proxy true;

        # Enables WS support
        proxy_http_version 1.1;
        proxy_set_header Upgrade $http_upgrade;
        proxy_set_header Connection "upgrade";
        proxy_redirect off;
    }


    location /transmission/web {
        proxy_pass http://localhost:9091;

        proxy_pass_header  X-Transmission-Session-Id;
        proxy_set_header   X-Forwarded-Host $host;
        proxy_set_header   X-Forwarded-Server $host;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

        # Enables WS support
        proxy_http_version 1.1;
        proxy_set_header Upgrade $http_upgrade;
        proxy_set_header Connection "upgrade";
        proxy_redirect off;
    }

    listen 443 ssl; # managed by Certbot
    ssl_certificate /etc/letsencrypt/live/dovgastreetnas.viewdns.net/fullchain.pem; # managed by Certbot
    ssl_certificate_key /etc/letsencrypt/live/dovgastreetnas.viewdns.net/privkey.pem;       # managed by Certbot
    include /etc/letsencrypt/options-ssl-nginx.conf; # managed by Certbot
  }
希望这能帮助别人