简体   繁体   English

如何在不使用 nginx 的浏览器中更改 url 的情况下重写 url

[英]how can I rewrite url without changing url in the browser with nginx

I have a static page in my wordpress,我的 wordpress 中有一个静态页面,

https://www.mrtrobotics.com/naplan https://www.mrtrobotics.com/naplan

and I would like to use subdomain for this page我想为此页面使用子域

edu.mrtrobotics.com edu.mrtrobotics.com

now when I use edu.mrtrobotics.com ---> it goes to https://www.mrtrobotics.com/naplan现在当我使用 edu.mrtrobotics.com ---> 它转到https://www.mrtrobotics.com/naplan

but it shows in the url of browser as https://www.mrtrobotics.com/naplan但它在浏览器的 url 中显示为https://www.mrtrobotics.com/naplan

I want it to be shown as edu.mrtrobotics.com to user.我希望它向用户显示为 edu.mrtrobotics.com。

what should I do ??我该怎么办 ??

server {
    listen 80;
    listen [::]:80;

    server_name mrtrobotics.com www.mrtrobotics.com;

    location ~ /.well-known/acme-challenge {
        allow all;
        root /var/www/html;
    }

    location / {
        rewrite ^ https://$host$request_uri? permanent;
    }
}

server {
    listen 80;
    listen 443 ssl http2;
    listen [::]:443 ssl http2;
    server_name edu.mrtrobotics.com;

    ssl_certificate /etc/letsencrypt/live/mrtrobotics.com/fullchain.pem;
    ssl_certificate_key /etc/letsencrypt/live/mrtrobotics.com/privkey.pem;

    include /etc/nginx/conf.d/options-ssl-nginx.conf;

    rewrite ^ https://mrtrobotics.com/naplan permanent;
}

server {
    listen 443 ssl http2;
    listen [::]:443 ssl http2;
    server_name mrtrobotics.com www.mrtrobotics.com;

    index index.php index.html index.htm;

    root /var/www/html;

    server_tokens off;

    ssl_certificate /etc/letsencrypt/live/mrtrobotics.com/fullchain.pem;
    ssl_certificate_key /etc/letsencrypt/live/mrtrobotics.com/privkey.pem;

    include /etc/nginx/conf.d/options-ssl-nginx.conf;

    add_header X-Frame-Options "SAMEORIGIN" always;
    add_header X-XSS-Protection "1; mode=block" always;
    add_header X-Content-Type-Options "nosniff" always;
    add_header Referrer-Policy "no-referrer-when-downgrade" always;
    add_header Content-Security-Policy "default-src * data: 'unsafe-eval' 'unsafe-inline'" always;
    # add_header Strict-Transport-Security "max-age=31536000; includeSubDomains; preload" always;
    # enable strict transport security only if you understand the implications

    location / {
        try_files $uri $uri/ /index.php$is_args$args;
    }

    location ~ \.php$ {
        try_files $uri =404;
        fastcgi_split_path_info ^(.+\.php)(/.+)$;
        fastcgi_pass wordpress:9000;
        fastcgi_index index.php;
        include fastcgi_params;
        fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
        fastcgi_param PATH_INFO $fastcgi_path_info;
    }

    location ~ /\.ht {
        deny all;
    }

    location = /favicon.ico {
        log_not_found off; access_log off;
    }
    location = /robots.txt {
        log_not_found off; access_log off; allow all;
    }
    location ~* \.(css|gif|ico|jpeg|jpg|js|png)$ {
        expires max;
        log_not_found off;
    }
}

# Set client upload size - 100Mbyte
client_max_body_size 100M;

# to avoid 504 time out error - defalut is 60s
proxy_send_timeout 180s;
proxy_read_timeout 180s;
fastcgi_send_timeout 180s;
fastcgi_read_timeout 180s;

Your server that handles edu.mrtrobotics.com should not have that rewrite rule, once you do a permanent rewrite you will send a 301 back to the browser and the URL will change.您处理 edu.mrtrobotics.com 的服务器不应该有该重写规则,一旦您进行永久重写,您将向浏览器发送 301,并且 URL 将更改。 If /naplan really is the only thing that should be served from the edu subdomain, then perhaps you want something like this?如果 /naplan 真的是 edu 子域中唯一应该提供的服务,那么也许您想要这样的东西?

server {
    listen 80;
    listen 443 ssl http2;
    listen [::]:443 ssl http2;
    server_name edu.mrtrobotics.com;

    ssl_certificate /etc/letsencrypt/live/mrtrobotics.com/fullchain.pem;
    ssl_certificate_key /etc/letsencrypt/live/mrtrobotics.com/privkey.pem;

    include /etc/nginx/conf.d/options-ssl-nginx.conf;
    root /var/www/html;

    location / {
        try_files /naplan/$uri /naplan =404;
    }
}

Update , as /naplan is a folder, try...更新,因为 /naplan 是一个文件夹,请尝试...

server {
    listen 80;
    listen 443 ssl http2;
    listen [::]:443 ssl http2;
    server_name edu.mrtrobotics.com;

    ssl_certificate /etc/letsencrypt/live/mrtrobotics.com/fullchain.pem;
    ssl_certificate_key /etc/letsencrypt/live/mrtrobotics.com/privkey.pem;

    include /etc/nginx/conf.d/options-ssl-nginx.conf;
    root /var/www/html;

    location / {
        root /var/www/html/naplan;
    }
}

Good luck :-)祝你好运 :-)

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM