HTTPS 协议是由 HTTP 加上 TLS/SSL 协议构建的可进行加密传输、身份认证的网络协议,主要通过数字证书、加密算法、非对称密钥等技术完成互联网数据传输加密,实现互联网传输安全保护。这篇文章记录了本站从HTTP升级到HTTPS的全过程,以及中间遇到的一些问题。
一、申请 SSL 证书
- SSL证书有付费的和免费的,这里我选择了阿里云提供的一年免费SSL证书
- 在阿里云控制台中搜索找到 SSL 证书应用,选择 SSL 证书菜单,免费证书,创建证书,创建证书时需要指定域名等信息,确定之后等审核通过即可下载。审核很快,我等了几分钟审核就通过了。
- 阿里云平台的一些服务器产品可以自动部署 SSL 证书,这里我的服务器不支持,所以手动部署(详细部署过程可以参考阿里云帮助文档)。
二、Nginx 部署证书
- 将申请好的证书下载下来,上传到自己服务器中,我放到了根目录/ssl下面。
- 修改 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;
}
}
- 配置 http 自动跳转 https(可以不配置)
server {
listen 80;
server_name yourdomain.com; #需要将yourdomain.com替换成证书绑定的域名。
rewrite ^(.*)$ https://$host$1; #将所有HTTP请求通过rewrite指令重定向到HTTPS。
}
三、Docker 下的特殊配置
- 由于我的 Nginx 是部署在 docker 中的,所以有些地方需要不一样的配置。
- SSL 证书需要挂载到容器中,否则容器中的nginx无法读取到SSL证书,网站无法访问。
- 端口需要额外映射一个 443 端口,否则无法访问到 Nginx 中。我在配置的时候忽略的这个问题,一直无法成功访问到 HTTPS 的网站,后来终于发现了问题所在:我误解了上文中 HTTP 自动跳转 HTTPS 的配置,该配置的意思是浏览器访问 80 端口的 HTTP 时,nginx会让浏览器自动重定向到 443 端口的 HTTPS;而我以为这是内部跳转,没有开放 443 端口,所以始终无法访问。
- 删除 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
四、总结
- HTTP升级HTTPS,主要就是首先需要获取证书,有免费和付费的,然后将证书上传至服务器,接着在nginx中配置好相应的SSL证书、加密信息,接着重启 nginx 即可。
- 出现无法访问的问题可以查看 nginx 的 error.log,看看是不是 SSL 证书配置写错了,还有就是服务器防火墙 443 的端口是否开放了,如果是运行在docker中则需要映射 443 端口。
评论区