AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 109397
Accepted
user8585
user8585
Asked: 2010-02-04 17:10:04 +0800 CST2010-02-04 17:10:04 +0800 CST 2010-02-04 17:10:04 +0800 CST

nginx 子域不正确地像通配符一样?

  • 772

我对 nginx 子域有一个奇怪的问题。首先,我的配置:

server {
    listen              443 ssl;
    server_name         secure.example.com;
    ssl_certificate     example.crt;
    ssl_certificate_key example.key;
    keepalive_timeout   70;

    location / {
        fastcgi_pass    127.0.0.1:8000;
        ...
    }
}

server {
    listen              80;
    server_name         example.com www.example.com;

    location / {
        fastcgi_pass    127.0.0.1:8000;
        ...
    }
}

我的想法是我有一个安全域secure.example.com和一个普通域,example.com. 在实践中,我可以去https://example.com和http://secure.example.com。我使用中间服务器解决了第二个问题:

server {
    listen              80;
    server_name         secure.example.com;
    rewrite     ^(.*)  https://secure.example.com$1 permanent;
}

但这不是最佳解决方案,我必须创建另一个以将 tld 上的 https 重定向到子域。如果我需要多个这样的服务器,我觉得我一定做错了。为什么https://example.com在没有服务器监听 443 的情况下工作?它不应该只是无法连接吗?我比较困惑。

subdomain nginx
  • 2 2 个回答
  • 3158 Views

2 个回答

  • Voted
  1. Best Answer
    joschi
    2010-03-09T03:47:11+08:002010-03-09T03:47:11+08:00

    为什么https://example.com在没有服务器监听 443 的情况下工作?它不应该只是无法连接吗?

    在server_name80/tcp (HTTP) 或 443/tcp (HTTPS) 上的连接建立后评估(或更准确地说是 HTTP/1.1 Host 标头)。这意味着如果secure.example.com和example.com拥有相同的 A 资源记录(它们指向相同的 IP 地址),那么在建立连接和 HTTP/1.1 Host 标头之前,无法判断客户端要查看哪个虚拟主机发送。

    更准确地说,TCP/IP 与 IP 地址(IP 部分)和端口(TCP 部分)一起工作。因此,如果您将进程(例如 nginx)绑定到某个 IP 地址和端口,它将始终在此套接字上应答,而 TCP/IP 对 HTTP/1.1 及其 Host 标头一无所知。

    如果您想简化您的 nginx 配置,您可以编写以下代码:

    server {
        listen              443 ssl;
        listen              80;
    
        server_name         secure.example.com;
        ssl_certificate     example.crt;
        ssl_certificate_key example.key;
        keepalive_timeout   70;
    
        if ($scheme = http) {
            rewrite  ^(.+)$  https://example.com$1  redirect;            
        }
    
        location / {
            fastcgi_pass    127.0.0.1:8000;
            # ...
        }
    }
    
    server {
        listen              80;
        server_name         example.com www.example.com;
    
        location / {
            fastcgi_pass    127.0.0.1:8000;
            # ...
        }
    }
    
    • 1
  2. clement
    2010-02-04T21:53:25+08:002010-02-04T21:53:25+08:00

    查看 Nginx server_name 文档。它表示如果您的虚拟主机列表中没有任何匹配项,nginx 将使用第一个server {}块和匹配的监听指令。

    如果您想强制用户使用带有https的secure.example.com主机,您可以采用与相反情况相同的解决方法。

    • 0

相关问题

  • 通配符 DNS 和子域

  • nginx HTTPS 服务与 HTTP 相同的配置

  • nginx 工作进程的数量

  • 使用Passenger时使用Nginx over Apache with Rails的优缺点是什么

  • 阿帕奇的替代品

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    从 IP 地址解析主机名

    • 8 个回答
  • Marko Smith

    如何按大小对 du -h 输出进行排序

    • 30 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    MikeN 在 Nginx 中,如何在维护子域的同时将所有 http 请求重写为 https? 2009-09-22 06:04:43 +0800 CST
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    0x89 bash中的双方括号和单方括号有什么区别? 2009-08-10 13:11:51 +0800 CST
  • Martin Hope
    Kyle Brandt IPv4 子网如何工作? 2009-08-05 06:05:31 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve