为nginx服务器添加SSL证书
首先去阿里云去申请免费的SSL证书,个人每年可以申请20个单域名SSL测试证书,没改版前证书有效期是1年,改版后只有3个月有效期,也可以花钱购买企业服务延长期限
点击创建一个SSL证书,输入要绑定的域名,然后带点击提交审核
审核完成后,点击下载nginx用的SSL证书文件,下载nginx版本的
上传证书到该conf配置文件夹并解压,如conf/cert
编辑nginx配置,在http模块内加入以下配置
#以下属性中,以ssl开头的属性表示与证书配置有关。
server {
listen 443 ssl;
#配置HTTPS的默认访问端口为443。
#如果未在此处配置HTTPS的默认访问端口,可能会造成Nginx无法启动。
#如果您使用Nginx 1.15.0及以上版本,请使用listen 443 ssl代替listen 443和ssl on。
server_name www.xxx.com;
root html;
index index.html index.htm;
ssl_certificate cert/www.xxx.com.pem;
ssl_certificate_key cert/www.xxx.com.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协议的类型,您需要自行评估是否配置TLSv1.1协议。
ssl_prefer_server_ciphers on;
location / {
root html; #Web网站程序存放目录。
index index.html index.htm;
}
}
nginx -s reload重启
旧80访问重定向到443
在http节点中添加以下配置,然后将以前的location配置移到443节点下
server {
listen 80;
server_name www.xxx.com; #需要将yourdomain替换成证书绑定的域名。
rewrite ^(.*)$ https://$host$1; #将所有HTTP请求通过rewrite指令重定向到HTTPS。
location / {
index index.html index.htm;
}
}
重新访问地址刷新查看就显示连接安全了