云服务器 nginx配置SSL证书

本文详细介绍如何在阿里云购买服务器证书,并在Nginx上配置HTTPS,包括证书下载、Nginx配置更新及常见问题解决,如SSL错误和HTTP重定向HTTPS。

阿里云的服务器 证书已经买好了,如果不会买,可以看阿里云的帮助文档

证书准备好后,点击下载

根据你web服务器的类型,下载相应证书

我的是nginx 所以下载的是nginx的证书

在nginx安装目录中,创建文件夹cert

把这两个文件上传到nginx/cert中

Nginx nginx.conf配置

server {
        charset utf-8;
        client_max_body_size 30M;
        listen 443 ssl http2 default_server; #443默认端口
        listen [::]:443 ssl http2 default_server;
        server_name www.wangzhan.com; #你的网站
        ssl on;
        root /var/www/wangzhan/; #你网站的地址
        index index.html index.htm index.php;
        ssl_certificate  cert/2434986.pem; #证书文件地址
        ssl_certificate_key cert/2434986.key;#证书文件地址
        ssl_session_timeout 5m;
        ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4;
        ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
        ssl_prefer_server_ciphers on;
     location / {
        try_files $uri $uri/ /index.html;
     }
     location ~^/(api|upload|share|common)/ { #反向代理地址
        proxy_pass http://localhost:8080;
        proxy_http_version 1.1;
        proxy_set_header Upgrade $http_upgrade;
        proxy_set_header Connection ‘upgrade’;
        proxy_set_header Host $host;
        proxy_cache_bypass $http_upgrade;
     }
     error_page 404 /404.html;
      location ~ /\.(ht|svn|git) {
      deny all;
     }
   }

配置可以参考,但不要全部复制

配置完成后,检查一下nginx配置文件是否可用,有successful表示可用。

nginx -t // 检查nginx配置文件

配置正确后,重新加载配置文件使配置生效:

nginx -s reload // 使配置生效

其他命令

service nginx stop // 停止
service nginx start // 启动
service nginx restart // 重启

说明:如果是云服务器是阿里云ECS,需要到阿里云ECS的管理后台的安全组,修改端口过滤规则把80端口和443端口开放才能访问到。

如果配置好https后,也能访问,但是浏览器提示连接不安全

说明在网站中使用的js css img连接中还存在http的请求连接,

需要整站进行筛选替换为https才会变成绿色的小锁

如果配置完成后,火狐报-SSL 接收到一个超出最大准许长度的记录【ssl_error_rx_record_too_long】

解决方案:

修改配置文件 nginx.conf

修改server里面的 listen 443;  为  listen 443 default ssl; 

保存,重启Nginx。完美解决!

当ssl配置完成后,还得处理一下http访问的情况

增加nginx.conf配置处理

server {
    listen 80;
    server_name www.wangzhan.com;
    rewrite  ^(.*)  https://$server_name$document_uri permanent;
   }

配置完成后,重新加载配置,然后重启nginx;之后在访问你的网站使用http协议的话,会自动重写替换为https访问网站。

### 腾讯云 Nginx 服务器 SSL 证书安装部署(Windows) 要在 Windows 系统上为 Nginx 配置 SSL 证书并使用腾讯云的服务或证书,可以参考以下方法: #### 准备工作 1. **下载 SSL 证书** 登录腾讯云控制台,在 SSL 证书管理页面找到已购买的证书,点击“下载”,选择适合 Nginx证书包。通常会得到两个文件:`*.crt` 和 `*.key`。 2. **上传证书至服务器** 将下载的 `.crt` 文件和 `.key` 文件保存到 Nginx 安装目录下的适当位置,例如 `conf` 或专门创建的子目录 `/certs` 中。 --- #### 修改 Nginx 配置文件 编辑 Nginx配置文件 `nginx.conf`,添加或修改如下内容: ```nginx server { listen 443 ssl; server_name yourdomain.com; # 设置 SSL 证书路径 ssl_certificate C:/path/to/your/certificate.crt; # 替换为 crt 文件的实际路径 [^1] ssl_certificate_key C:/path/to/your/private.key; # 替换为 key 文件的实际路径 [^1] # SSL 连接优化设置 ssl_session_timeout 5m; ssl_protocols TLSv1.2 TLSv1.3; # 推荐启用较新的协议版本 [^2] ssl_ciphers HIGH:!aNULL:!MD5; # 加密算法建议保持高强度 [^2] ssl_prefer_server_ciphers on; # 网站根目录设置 root C:/path/to/your/webroot; # 替换为网站静态资源所在的路径 [^4] index index.html index.htm; location / { try_files $uri $uri/ =404; } # 可选:反向代理配置 (如果有后端服务) location /api/ { proxy_set_header Host $http_host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header REMOTE-HOST $remote_addr; add_header 'Access-Control-Allow-Credentials' 'true'; add_header 'Access-Control-Allow-Origin' '*'; # 如果需要跨域支持可保留此选项 [^4] add_header 'Access-Control-Allow-Methods' 'GET, POST, PATCH, OPTIONS'; proxy_pass http://localhost:15666/; } } ``` > 注意事项:确保所有路径均为 Windows 绝对路径格式 (`C:\...`) 并替换占位符为你的真实环境参数。 --- #### 测试与启动 Nginx 完成以上配置后,执行以下命令测试配置文件语法是否正确,并重新加载 Nginx: 1. 打开 CMD 命令提示符窗口。 2. 输入以下命令验证配置文件是否有误: ```bash nginx -t ``` 若无错误信息则继续下一步。 3. 启动或重载 Nginx: ```bash nginx -s reload ``` --- #### 开放必要的防火墙端口 为了确保 HTTPS 正常运行,请确认以下端口已在系统防火墙中开放: - HTTP 默认端口:80 - HTTPS 默认端口:443 可以通过以下方式开启防火墙规则(以 PowerShell 为例): ```powershell New-NetFirewallRule -DisplayName "Allow NGINX Port 443" -Direction Inbound -LocalPort 443 -Protocol TCP -Action Allow New-NetFirewallRule -DisplayName "Allow NGINX Port 80" -Direction Inbound -LocalPort 80 -Protocol TCP -Action Allow ``` --- ### 总结 通过上述步骤可以在 Windows 环境下成功为 Nginx 配置 SSL 证书,并利用腾讯云提供的服务实现安全连接[^3]。务必仔细核对每一步中的路径以及证书文件名准确性,避免因拼写错误导致无法正常启动服务。
评论 6
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

JSON_L

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值