侧边栏壁纸
  • 累计撰写 12 篇文章
  • 累计创建 11 个标签
  • 累计收到 2 条评论

目 录CONTENT

文章目录

HTTP升级HTTPS记录

bingo
2021-12-14 / 1 评论 / 1 点赞 / 2,975 阅读 / 1,134 字 / 正在检测是否收录...
温馨提示:
本文最后更新于 2023-12-29,若内容或图片失效,请留言反馈。部分素材来自网络,若不小心影响到您的利益,请联系我们删除。

HTTPS 协议是由 HTTP 加上 TLS/SSL 协议构建的可进行加密传输、身份认证的网络协议,主要通过数字证书、加密算法、非对称密钥等技术完成互联网数据传输加密,实现互联网传输安全保护。这篇文章记录了本站从HTTP升级到HTTPS的全过程,以及中间遇到的一些问题。

一、申请 SSL 证书

  1. SSL证书有付费的和免费的,这里我选择了阿里云提供的一年免费SSL证书
  2. 在阿里云控制台中搜索找到 SSL 证书应用,选择 SSL 证书菜单,免费证书,创建证书,创建证书时需要指定域名等信息,确定之后等审核通过即可下载。审核很快,我等了几分钟审核就通过了。
  3. 阿里云平台的一些服务器产品可以自动部署 SSL 证书,这里我的服务器不支持,所以手动部署(详细部署过程可以参考阿里云帮助文档)。

二、Nginx 部署证书

  1. 将申请好的证书下载下来,上传到自己服务器中,我放到了根目录/ssl下面。
  2. 修改 Nginx 配置文件,指定监听 443 端口,指定 SSL 证书位置。
#以下属性中,以ssl开头的属性表示与证书配置有关。
server {
    listen 443 ssl;
    #配置HTTPS的默认访问端口为443。
    #如果未在此处配置HTTPS的默认访问端口,可能会造成Nginx无法启动。
    #如果您使用Nginx 1.15.0及以上版本,请使用listen 443 ssl代替listen 443和ssl on。
    server_name yourdomain.com; #需要将yourdomain.com替换成证书绑定的域名。
    root html;
    index index.html index.htm;
    ssl_certificate cert/cert-file-name.pem;  #需要将cert-file-name.pem替换成已上传的证书文件的名称。
    ssl_certificate_key cert/cert-file-name.key; #需要将cert-file-name.key替换成已上传的证书私钥文件的名称。
    ssl_session_timeout 5m;
    ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4;
    #表示使用的加密套件的类型。
    ssl_protocols TLSv1.1 TLSv1.2 TLSv1.3; #表示使用的TLS协议的类型。
    ssl_prefer_server_ciphers on;
    location / {
        root html;  #站点目录。
        index index.html index.htm;
    }
}
  1. 配置 http 自动跳转 https(可以不配置)
server {
    listen 80;
    server_name yourdomain.com; #需要将yourdomain.com替换成证书绑定的域名。
    rewrite ^(.*)$ https://$host$1; #将所有HTTP请求通过rewrite指令重定向到HTTPS。
}

三、Docker 下的特殊配置

  1. 由于我的 Nginx 是部署在 docker 中的,所以有些地方需要不一样的配置。
  2. SSL 证书需要挂载到容器中,否则容器中的nginx无法读取到SSL证书,网站无法访问。
  3. 端口需要额外映射一个 443 端口,否则无法访问到 Nginx 中。我在配置的时候忽略的这个问题,一直无法成功访问到 HTTPS 的网站,后来终于发现了问题所在:我误解了上文中 HTTP 自动跳转 HTTPS 的配置,该配置的意思是浏览器访问 80 端口的 HTTP 时,nginx会让浏览器自动重定向到 443 端口的 HTTPS;而我以为这是内部跳转,没有开放 443 端口,所以始终无法访问。
  4. 删除 docker 中的 nginx 容器,重新启动容器,这里主要是映射了两个端口(我也是第一次知道原来 docker 容器可以映射多个端口),和 ssl 文件夹:
docker run -p 80:80 -p 443:443 --name nginx \
-v /root/nginx/html:/usr/share/nginx/html \
-v /root/nginx/logs:/var/log/nginx  \
-v /root/nginx/conf:/etc/nginx \
-v /root/nginx/js:/usr/share/nginx/js \
-v /ssl:/ssl \
-d nginx:1.21.3

四、总结

  1. HTTP升级HTTPS,主要就是首先需要获取证书,有免费和付费的,然后将证书上传至服务器,接着在nginx中配置好相应的SSL证书、加密信息,接着重启 nginx 即可。
  2. 出现无法访问的问题可以查看 nginx 的 error.log,看看是不是 SSL 证书配置写错了,还有就是服务器防火墙 443 的端口是否开放了,如果是运行在docker中则需要映射 443 端口。
1

评论区