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(管理员权限),执行:

bash 复制代码
:: 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.keyrootCA.crt

步骤二:为 Nginx 生成服务器证书

1. 创建配置文件 server.csr.cnf

在Windows用户目录(如 C:\Users\[用户名])创建文件:server.csr.cnf,内容如下:

bash 复制代码
[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. 生成服务器证书

bash 复制代码
:: 生成服务器私钥
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 块,修改或替换为:

bash 复制代码
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 目录下操作:

bash 复制代码
:: 测试配置是否正确
nginx.exe -t

:: 启动 Nginx
start nginx

:: (可选)重启
nginx.exe -s reload

:: (可选)停止
nginx.exe -s quit

验证效果

在局域网任意设备浏览器访问:

应该看到:

地址栏绿色锁图标

无"您的连接不是私密连接"警告

证书由 My Private CA 签发

相关推荐
小楊不秃头3 小时前
网络原理:数据链路层、NAT与网页加载
网络·网络协议
上海云盾第一敬业销售3 小时前
游戏盾是如何保障游戏安全稳定的
tcp/ip·安全·游戏·ddos
The 旺4 小时前
【Rust实战】打造内存安全的网络代理:深入异步IO与并发编程
网络·安全·rust
鼓掌MVP4 小时前
CodeBuddy编程实现:基于EdgeOne边缘安全加速平台的远程计算资源共享技术平台
安全
matlab8889994 小时前
Falco:云原生世界中的安全守护者
其他·安全·云原生
我叫汪枫4 小时前
《HTTP 的进化史:从 1.0 到 3.0 的飞跃》
网络·网络协议·http
普普通通的南瓜5 小时前
政务领域应用:国密 SSL 证书如何守护 “一网通办” 的数据安全?
https·ssl·政务
我叫汪枫5 小时前
《拆解一封网络信:HTTP 报文详解》
网络·网络协议·http
我叫汪枫5 小时前
《HTTP 中的“握手”:从 TCP 到 TLS 的安全通信之旅》
tcp/ip·安全·http