用于从现有短链接web服务创建短链接服务的NGINX配置

用于从现有短链接web服务创建短链接服务的NGINX配置,nginx,laravel-5.6,laravel-forge,Nginx,Laravel 5.6,Laravel Forge,我有一个长域名的短链接服务longname.com/Wsdfsdf。当访问者单击此链接时,它会重定向到longname.com/order details/customer id/3435345435 现在我有了一个短域名,比如sh.rt,我希望每个longname.com/*的行为都与sh.rt/* 因此,当访问者访问sh.rt/Wsdfsdf时,它将重定向到longname.com/order details/customer id/3435345435,与longname.com/Wsdf

我有一个长域名的短链接服务
longname.com/Wsdfsdf
。当访问者单击此链接时,它会重定向到
longname.com/order details/customer id/3435345435

现在我有了一个短域名,比如
sh.rt
,我希望每个
longname.com/*
的行为都与
sh.rt/*

因此,当访问者访问
sh.rt/Wsdfsdf
时,它将重定向到
longname.com/order details/customer id/3435345435
,与
longname.com/Wsdfsdf
相同

通过这样做,我不必为
sh.rt

我试图将servername中的域名添加到NGINX配置文件中,但问题可能是
longname.com
具有默认ssl,而
sh.rt
没有

我的Nginx文件是:

include forge-conf/mydomain.com/before/*;


server {
      proxy_connect_timeout       600;
  proxy_send_timeout          600;
  proxy_read_timeout          600;
  send_timeout                600;

    listen 443 ssl http2;
    listen [::]:443 ssl http2;
    server_name .mydomain.com;
    root /home/forge/mydomain.com/public;

    # FORGE SSL (DO NOT REMOVE!)
    ssl_certificate /etc/nginx/ssl/mydomain.com/330472/server.crt;
    ssl_certificate_key /etc/nginx/ssl/mydomain.com/330472/server.key;

    ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
    ssl_ciphers '...';
    ssl_prefer_server_ciphers on;
    ssl_dhparam /etc/nginx/dhparams.pem;

    add_header X-Frame-Options "SAMEORIGIN";
    add_header X-XSS-Protection "1; mode=block";
    add_header X-Content-Type-Options "nosniff";

    index index.html index.htm index.php;

    charset utf-8;

    # FORGE CONFIG (DO NOT REMOVE!)
    include forge-conf/mydomain.com/server/*;

    location / {
        try_files $uri $uri/ /index.php?$query_string;
    }

    location = /favicon.ico { access_log off; log_not_found off; }
    location = /robots.txt  { access_log off; log_not_found off; }

    access_log off;
    error_log  /var/log/nginx/mydomain.com-error.log error;

    error_page 404 /index.php;

    location ~ \.php$ {
        fastcgi_split_path_info ^(.+\.php)(/.+)$;
        fastcgi_pass unix:/var/run/php/php7.2-fpm.sock;
        fastcgi_index index.php;
        include fastcgi_params;
    }

    location ~ /\.(?!well-known).* {
        deny all;
    }
}

# FORGE CONFIG (DO NOT REMOVE!)
include forge-conf/mydomain.com/after/*;

假设您希望两个站点提供相同的内容:

server_name ~^longname.com|sh.rt$;
这可能会导致SSL证书出现问题,但您声明不希望使用单独的服务器块。如果我是你,我会将其配置为具有相同
根目录的额外服务器块。这也是一个问题

有关其他文档,请参阅:


是,内容为longname.com/*。因为longname.com/*已经重定向到longername(logname.com/orders/w324324 extended name)。因此,它的行为将与longname shortlink的行为完全相同。我将尝试一下,并让您知道。我还提出了一个服务器故障问题。