Springboot 局域网部署https解除安全警告
在 Windows 环境下,使用 Windows 版 Nginx 部署 HTTPS,并让浏览器访问局域网地址(如 https://192.168.1.100)不显示安全警告,你需要:
✅ 创建一个受信任的 HTTPS 证书(自签名 + 根 CA)
✅ 配置 Windows 版 Nginx 使用该证书
✅ 将根证书安装到 Windows 系统信任列表(关键!否则浏览器会警告)
完整步骤(Windows 环境)
🧰 准备工具
1、OpenSSL for Windows(用于生成证书)
下载:https://slproweb.com/products/Win32OpenSSL.html
推荐下载 Win64 OpenSSL v3.x Light(绿色版即可)
安装后将 C:\Program Files\OpenSSL-Win64\bin 加入系统 PATH
2、Nginx for Windows
下载:http://nginx.org/en/download.html
解压到任意目录,如:C:\nginx
步骤一:生成私有根证书(Root CA)
打开 CMD 或 PowerShell(管理员权限),执行:
:: 1. 生成根私钥
openssl genrsa -out rootCA.key 2048:: 2. 生成根证书(有效期 10 年)
openssl req -x509 -new -nodes -key rootCA.key ^-sha256 -days 3650 ^-out rootCA.crt ^-subj "/C=CN/ST=Local/L=Local/O=MyOrg/CN=My Private CA"
会在Windows用户目录下生成文件:rootCA.key 和 rootCA.crt
步骤二:为 Nginx 生成服务器证书
1. 创建配置文件 server.csr.cnf
在Windows用户目录(如 C:\Users\[用户名])创建文件:server.csr.cnf,内容如下:
[req]
default_bits = 2048
prompt = no
default_md = sha256
distinguished_name = dn
req_extensions = v3_req[dn]
C=CN
ST=Local
L=Local
O=MyOrg
OU=Dev
CN=192.168.1.100[v3_req]
basicConstraints = CA:FALSE
keyUsage = nonRepudiation, digitalSignature, keyEncipherment
subjectAltName = @alt_names[alt_names]
IP.1 = 192.168.1.100
IP.2 = 192.168.1.101
DNS.1 = web.local
DNS.2 = localhost
修改 IP.1 为你本机的局域网 IP(如 192.168.1.100)
2. 生成服务器证书
:: 生成服务器私钥
openssl genrsa -out server.key 2048:: 生成证书请求
openssl req -new -key server.key -out server.csr -config server.csr.cnf:: 用根 CA 签发服务器证书
openssl x509 -req -in server.csr ^-CA rootCA.crt -CAkey rootCA.key ^-CAcreateserial ^-out server.crt ^-days 1825 ^-sha256 ^-extfile server.csr.cnf ^-extensions v3_req
会在Windows用户目录下生成文件:server.crt 和 server.key
步骤三:配置 Nginx 使用 HTTPS
1. 将证书复制到 Nginx 配置目录
将以下文件放入 C:\nginx\conf\ssl(手动创建 ssl 文件夹):
server.crt
server.key
2. 修改 C:\nginx\conf\nginx.conf
找到 server 块,修改或替换为:
server {listen 443 ssl;server_name 192.168.1.100;ssl_certificate conf/ssl/server.crt;ssl_certificate_key conf/ssl/server.key;ssl_protocols TLSv1.2 TLSv1.3;ssl_ciphers HIGH:!aNULL:!MD5;location / {root html;index index.html index.htm;}
}# 可选:HTTP 自动跳转 HTTPS
server {listen 80;server_name 192.168.1.100;return 301 https://$host$request_uri;
}
server_name 改为你的局域网 IP
步骤四:安装根证书到 Windows 信任列表(关键!)
这是让浏览器不报警告的核心!
打开 文件资源管理器,找到 rootCA.crt
双击打开 → “安装证书”
选择“本地计算机”(需要管理员权限)
存放位置:“受信任的根证书颁发机构”
点击完成
安装成功后,所有基于 Windows 的浏览器(Chrome、Edge、Firefox*)都将信任你签发的证书。
Firefox 使用自己的证书库,需额外导入:打开 Firefox → 设置 → 隐私与安全 → 证书 → 查看证书 → 机构 → 导入 rootCA.crt
步骤五:启动 Nginx
在 C:\nginx 目录下操作:
:: 测试配置是否正确
nginx.exe -t:: 启动 Nginx
start nginx:: (可选)重启
nginx.exe -s reload:: (可选)停止
nginx.exe -s quit
验证效果
在局域网任意设备浏览器访问:
应该看到:
地址栏绿色锁图标
无“您的连接不是私密连接”警告
证书由 My Private CA 签发
