【宝塔】局域网IP申请SSL证书,解决浏览器本地环境可以访问摄像头,发布环境不能访问摄像头的问题

前言

在本地开发环境 127.0.0.1localhost 中,通过 HTTP/IP 协议访问摄像头等设备时,浏览器可以正常请求到摄像头以及拿到画面。

然而,当项目迁移到发布环境后,使用 HTTP/IP 协议访问摄像头:提示开启摄像头失败:Cannot read properties of undefined (reading 'getUserMedia')

然后果断看了一下官网关于 navigator.mediaDevices 的描述,然后发现需要用到 HTTPS

因此这篇文章主要是介绍 Windows 如何申请SSL证书为局域网IP,然后在宝塔上面进行配置。

安装和配置 OpenSSL

  1. 安装 OpenSSL:

  2. 配置系统环境

申请证书

  1. 在 PowerShell 或 CMD 中:

    shell 复制代码
    mkdir C:\certs
    cd C:\certs
    
    openssl req -x509 -nodes -days 1825 -newkey rsa:2048 ^
      -keyout topmes-lan.key ^
      -out topmes-lan.crt ^
      -subj "/CN=10.0.222.110" ^
      -addext "subjectAltName=IP:10.0.222.110,DNS:localhost"

    10.0.222.110 可以替换成你需要申请 SLL 证书的 IP。申请成功以后如下图:

  2. 生成证书文件

    • topmes-lan.crttopmes-lan.key 可用于 Nginx。

    • 若用 IIS,可把 .crt 导入「受信任的根证书颁发机构」;IIS 绑定一般用 .pfx,可用下面命令从 crt+key 生成 pfx:

      shell 复制代码
      openssl pkcs12 -export -out topmes-lan.pfx -inkey topmes-lan.key -in topmes-lan.crt
      # 按提示设置 pfx 密码,IIS 导入时需填写

宝塔配置证书

在 宝塔 里已有用 局域网 IP域名 创建的网站,且根目录已指向前端 dist(或你的静态目录)。

若没有:网站添加站点 → 域名填 10.0.222.110(或你的 IP),根目录选好,先确保 HTTP 能访问。

部署 SSL(其他证书)

  1. 打开 宝塔网站 → 点击你的站点名(或 设置)。

  2. 左侧选择 SSL

  3. 在证书类型中选择 当前证书 (有的版本叫 自定义证书PEM 格式其他证书自有证书,依 宝塔 版本而定)。

  4. 填写两栏:

    • 私钥(KEY) :用记事本打开 C:\certs\topmes-lan.key全文复制 (含 -----BEGIN PRIVATE KEY----------END PRIVATE KEY-----)粘贴到进去。

    • 证书(PEM 格式) :用记事本打开 C:\certs\topmes-lan.crt全文复制 (含 -----BEGIN CERTIFICATE----------END CERTIFICATE-----)粘贴进去。

  5. 保存部署。保存后,宝塔会自动为该站点添加 443 监听并写好 Nginx/Apache 的 SSL 配置。

强制 HTTPS(可选)

SSL 页面勾选 强制 HTTPS ,使 http://192.168.1.100 自动跳转到 https://192.168.1.100

放行 443 端口

  • 宝塔 安全 / 防火墙 中添加入站规则:TCP 443 放行。
  • 若 宝塔 已自动放行 443,可跳过;否则 Windows 防火墙也需放行 443:
    • 管理员 PowerShell:New-NetFirewallRule -DisplayName "HTTPS-443" -Direction Inbound -Protocol TCP -LocalPort 443 -Action Allow

修改配置文件

需要将端口监听到 HTTPS,在端口号傍边加上 ssl 标记即可。

相关推荐
不会敲代码19 小时前
TCP/IP 与前端性能:从数据包到首次渲染的底层逻辑
前端·tcp/ip
S1998_1997111609•X10 小时前
论mysql国盾shell-sfa犯罪行为集团下的分项工程及反向注入原理尐深度纳米算法下的鐌檵鄐鉎行为
网络·数据库·网络协议·百度·开闭原则
以太浮标16 小时前
华为eNSP模拟器综合实验之- MGRE多点GRE隧道详解
运维·网络·网络协议·网络安全·华为·信息与通信
遇见火星16 小时前
Nginx 负载均衡配置模板:轮询、权重、IP哈希、最少连接
tcp/ip·nginx·负载均衡
时空自由民.17 小时前
WebSocket 协议介绍
网络·websocket·网络协议
mounter62519 小时前
深入理解 Linux 网络新特性:netkit 中的 RX/TX Queue Leasing 与 TCP Devmem
linux·服务器·网络·tcp/ip·kernel
时空自由民.19 小时前
CAN ,CANFD,EtherCAT介绍
网络协议·计算机网络
炘爚19 小时前
TCP三次握手和四次挥手
服务器·网络·tcp/ip
Gh0st_Lx20 小时前
【6】为什么有了 HTTP/1.1 ,还要 HTTP/2 和 HTTP/3
网络协议·http·php
学编程就要猛20 小时前
JavaEE初阶:网络原理-HTTP(下)
网络·网络协议·http