如何阻止 nginx 在我的公共 IP 上处理请求?

如何阻止 nginx 在我的公共 IP 上处理请求?

我使用 Ubuntu Server 上的 nginx 从家庭网络为 Pi 上的 2 个公共网站提供服务。我的域名指向我的 no-ip 帐户;两个域名都运行正常。但是,转到我的 IP 地址会返回我的一个网站,我已将其设置为仅使用其域名进行解析。如何强制我的 IP 提供未找到错误或指向其他网站?

我想阻止我的网站显示在我的 IP 上的原因是,由于我的网站仅使用 HTTPS,并且使用 HTTP 301,因此会显示不安全的连接。我宁愿那里什么都没有。

编辑: ../站点可用/站点名称

server {
    listen 443 ssl;

    root /var/www/****/www;
    index index.html index.php;

    server_name ****.ddns.net;
    server_name ****.**;
    server_name www.****.**;
    server_name ***.****.**;

    error_page 403 /403.html; 
    error_page 404 /404.html;
    error_page 500 502 503 504 /500.html;

    ssl_certificate /etc/letsencrypt/live/www.****.**/fullchain.pem;
    ssl_certificate_key /etc/letsencrypt/live/www.****.**/privkey.pem;

    ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
    ssl_prefer_server_ciphers on;
    ssl_ciphers 'EECDH+AESGCM:EDH+AESGCM:AES256+EECDH:AES256+EDH';

    location ~ \.php$ {
        try_files $uri =404;
        fastcgi_split_path_info ^(.+\.php)(/.+)$;
        fastcgi_pass unix:/var/run/php5-fpm.sock;
        fastcgi_index index.php;
        fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
        include fastcgi_params;
    }

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

server {
    listen 80;
    server_name www.****.**;
    server_name ****.**;
    server_name ***.****.**;
    return 301 https://$host$request_uri;
}

答案1

您可以定义一个具有空服务器名称的服务器来删除请求:

server {
    listen      80;
    listen      443;
    server_name "";
    return      444;
}

请注意,listen 443仅当您还想拒绝未知主机的 https 访问时才需要这样做。

来源

相关内容