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 / 问题 / 980475
Accepted
Wayne Werner
Wayne Werner
Asked: 2019-08-24 07:34:16 +0800 CST2019-08-24 07:34:16 +0800 CST 2019-08-24 07:34:16 +0800 CST

带有透明端口/代理的 Nginx 映射(?)

  • 772

我不完全确定我在这里寻找的是什么,所以我无法有效地搜索我的答案。

我正在为 LetsEncrypt 的 TLS-ALPN 挑战使用脱水。我正在使用 nginx 托管服务

stream {
    map $ssl_preread_alpn_protocols $tls_port {
        ~\bacme-tls/1\b 10443;
        default 3443;
    }

    server {
        listen 443;
        listen [::]:443;
        proxy_pass 127.0.0.1:$tls_port;
        ssl_preread on;
    }
}

server {
    listen 80 default_server;
    listen [::]:80 default_server;
    server_name _;
    return 301 https://$host$request_uri;
}

server {
    listen 3443 ssl;
    listen [::]:3443 ssl;

    server_name wanderingwerners.com www.wanderingwerners.com;

    ssl_certificate /path/to/my/fullchain.pem;
    ssl_certificate_key /path/to/my/privkey.pem;

    index index.html;
    root /var/www/wanderingwerners.com/;
}

这非常有效——我可以获得零停机时间的新证书,并且我的网站可以访问。但是,当我访问我的页面时,它工作正常。当我将鼠标悬停在链接上时,它会显示我https://www.wanderingwerners.com/a-beginning/

但是,单击该链接会将我带到https://www.wanderingwerners.com:3443/a-beginning/

这是不可取的-我希望它显示为普通的' https://www.wanderingwerners.com/a-beginning/

我假设我在 nginx 中设置的东西是造成混乱的原因,但我并不肯定。

有没有办法可以更新我的 nginx 配置以仍然允许脱水服务器工作,但也告诉浏览器这:3443不是他们应该连接的真正内容?(或者至少不要在地址栏中显示)

更新

当我这样做curl https://www.wanderingwerners.com/a-beginning时,它会给我一个 301 重定向。我的 nginx 配置在这里肯定发生了一些事情。

另一个更新

当我这样做时curl https://www.wanderingwernerx.com/a-beginning/,它工作得很好,所以看起来它正在用尾随做某事/

nginx
  • 2 2 个回答
  • 426 Views

2 个回答

  • Voted
  1. Tero Kilkanen
    2019-08-24T09:11:41+08:002019-08-24T09:11:41+08:00

    运行在端口 3443 上的网站软件很可能在其 HTML 代码中生成包含端口号的链接。

    您需要为软件找到一种方法来生成指向没有端口号的域的链接。

    我建议您的另一个更改是:

    server {
        listen 127.0.0.1:3443 ssl;
    
        server_name wanderingwerners.com www.wanderingwerners.com;
    
        ssl_certificate /path/to/my/fullchain.pem;
        ssl_certificate_key /path/to/my/privkey.pem;
    
        index index.html;
        root /var/www/wanderingwerners.com/;
    }
    

    使用此配置端口 3443 不会暴露在您的服务器之外,它只能从服务器本身访问。应用此配置意味着您需要先修复上一个问题。

    • 0
  2. Best Answer
    Michael Hampton
    2019-08-24T10:49:04+08:002019-08-24T10:49:04+08:00

    当您从 URL 中省略尾部斜杠时,您描述的重定向来自 nginx。你应该可以用port_in_redirect off;.

    • 0

相关问题

  • Gzip 与反向代理缓存

  • nginx 作为代理的行为

  • Nginx 学习资源 [关闭]

  • 提供 70,000 个静态文件 (jpg) 的最佳方式?

  • 在 Apache、LightTPD 和 Nginx Web 服务器上提供 PHP 5.x 应用程序的现状?

Sidebar

Stats

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

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

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

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

    • 9 个回答
  • Marko Smith

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

    • 3 个回答
  • Marko Smith

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

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +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