Nginx 中在 80 端口添加 HTTP/2 出现问题

承接上篇文章通过 Nginx 让网站支持 HTTP/2,当我完成文章中的操作时,有一次我好奇网站 HTTP 是否能够自动跳转到 HTTPS,于是我输入 http://blog.yidajiabei.xyz/ ,意外发生了——没有跳转到 HTTPS,还下载了一个名字为 download 且文件类型为 application/octet-stream

我很意外,思考这是为什么。把这个问题记下来,过了几个小时,我从网络中找到答案:HTTP2 不需要加密,当然这只是肤浅的说法,一定还有深层次的理解。

通过这篇文章,我学到一条检查网站是否支持 HTTP/2 的命令:

curl -I -k --http2 https://blog.yidajiabei.xyz/
HTTP/2 200 
server: nginx/1.18.0 (Ubuntu)
date: Wed, 03 Nov 2021 00:37:29 GMT
content-type: text/html
content-length: 5254
last-modified: Tue, 02 Nov 2021 23:37:46 GMT
etag: "6181cbca-1486"
accept-ranges: bytes

在这篇文章中,我找到了 Nginx 配置 HTTP/2 的方法:

http {
  server {
    listen 443 ssl http2;
    ssl_certificate    /path/to/server.cert;
    ssl_certificate_key /path/to/server.key;
    # ...
    # Copy from the HTTP server
    # ...
  }
}

根据这一配置,再联系到 HTTP/2 不需要加密,那么是不是不能在 80 端口配置 HTTP/2 呢?也就是说,以下配置会造成无法由 HTTP 跳转到 HTTPS:

http {
  server {
    listen 80 http2;
    # ...
  }
}

当这一切都被修正时,HTTP 就能够跳转到 HTTPS 了。

最终我的 Server Block 配置为

http {
  server {
    listen 443 ssl http2;
    server_name www.yidajiabei.xyz;
    ssl_certificate    /path/to/server.cert;
    ssl_certificate_key /path/to/server.key;
    # ...
    # Copy from the HTTP server
    # ...
  }
  server {
    listen 80;
    server_name www.yidajiabei.xyz yidajiabei.xyz;
    return 301 https://www.yidajiabei.xyz$request_uri;
  }
}
欢迎通过「邮件」或者点击「这里」告诉我你的想法
Welcome to tell me your thoughts via "email" or click "here"