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 签发

相关推荐
黎阳之光15 小时前
黎阳之光:以视频孪生领跑全球,赋能数字孪生水利智能监测新征程
大数据·人工智能·算法·安全·数字孪生
qq_2602412316 小时前
将盾CDN:网络安全态势感知的建设与实践
安全·web安全
一袋米扛几楼9817 小时前
【网络安全】Splunk 是什么?
安全·web安全
一袋米扛几楼9817 小时前
【网络安全】SIEM -Security Information and Event Management 工具是什么?
前端·安全·web安全
上海云盾-小余17 小时前
DDoS 攻击全解析:常见类型识别与分层防御思路
网络协议·tcp/ip·安全·ddos
www43918 小时前
Vulinbox(敏感信息与敏感文件泄露)
安全
不做菜鸟的网工18 小时前
H3C 本地 Portal + AAA 认证 模拟配置实验
网络协议
QYR_1118 小时前
2026塑料芯片卡产业全景:供应链成本结构与数字化安全趋势深度洞察
安全·市场调研
W.W.H.18 小时前
嵌入式常见的面试题1
linux·网络·经验分享·网络协议·tcp/ip
zmj32032418 小时前
CAN + 以太网 + Wi-Fi + BLE + TCP/IP + MQTT +HTTP协议层级
网络·网络协议·tcp/ip