首页 > 其他分享 >WEBRTC教程:局域网怎么调试,http://172.19.18.101:8080 ,无法访问摄像头和麦克风,请检查权限

WEBRTC教程:局域网怎么调试,http://172.19.18.101:8080 ,无法访问摄像头和麦克风,请检查权限

时间:2024-10-25 20:46:32浏览次数:8  
标签:浏览器 无法访问 局域网 HTTPS 使用 172.19 http server 调试

在局域网中使用 WebRTC 时,无法访问摄像头和麦克风通常是因为浏览器的安全策略限制了 getUserMedia API 的使用。如果你在非 localhost 或非 HTTPS 环境下访问网页,浏览器会阻止访问摄像头和麦克风。

解决方案

在局域网中调试 WebRTC 时,你有几个选项来解决这个问题:

1. 使用 localhost 访问

大多数浏览器允许在 localhost 上使用 getUserMedia,即使没有 HTTPS。所以你可以在服务器和客户端同一台机器上使用 localhost 进行测试。

示例

  • 访问 http://localhost:8080 进行调试。
  • 如果在局域网的其他机器上访问,这种方法不起作用。

2. 配置 HTTPS 证书

如果你需要在局域网的 IP 地址上(如 http://172.19.18.101)进行访问,那么使用 HTTPS 是解决方案之一。通过配置 HTTPS,你可以避免浏览器的安全限制。

步骤 1: 生成自签名证书(适用于本地开发)
  1. 使用 openssl 生成自签名证书:

    openssl req -nodes -new -x509 -keyout server.key -out server.cert
    
    • server.key:服务器的私钥。
    • server.cert:自签名的证书。
  2. 你可以用这些证书在服务器上配置 HTTPS。

步骤 2: 启动 HTTPS 服务器

如果你使用的是 http-server,可以用生成的证书来启动 HTTPS 服务器:

http-server -S -C server.cert -K server.key -p 8080

这样,你可以在局域网中使用 https://172.19.18.101:8080 进行访问。

3. 使用 ngrok 进行调试

ngrok 是一个方便的工具,可以创建一个 HTTPS 隧道,即使你在局域网中,它也可以为你提供一个 HTTPS 地址。

步骤:
  1. 安装 ngrok

    npm install -g ngrok
    
  2. 使用 ngrok 创建 HTTPS 隧道:

    ngrok http 8080
    
  3. ngrok 会生成一个 HTTPS 的 URL,你可以使用这个 URL 在任何设备上访问你的服务器。

4. 使用 chrome://flags 调试

在 Chrome 浏览器中,有一种方法可以关闭 HTTPS 限制(仅用于调试)。

  1. 在地址栏输入 chrome://flags
  2. 搜索 Insecure origins treated as secure
  3. Insecure origins treated as secure 中添加你的局域网 IP 地址,例如:http://172.19.18.101
  4. 重启 Chrome 浏览器。

注意:这种方法只适用于调试环境,不能用于生产环境。

5. 使用 Firefox 进行调试

Firefox 通常对本地 IP 地址的安全限制要比 Chrome 宽松一些,可以尝试使用 Firefox 进行调试,看看是否可以绕过安全限制。

6. 调试模式 (仅适用于开发环境)

如果你只是做开发调试,可以启动浏览器的无安全模式来绕过摄像头和麦克风的限制。

在 Chrome 中启动无安全模式(不推荐长期使用):
  1. 关闭所有 Chrome 浏览器窗口。

  2. 使用终端(Windows)或命令行(Linux/Mac),启动 Chrome:

    Windows

    chrome.exe --disable-web-security --user-data-dir="C:\chrome-dev"
    

    Mac/Linux

    google-chrome --disable-web-security --user-data-dir="/tmp/chrome-dev"
    

注意:这种方法仅限于开发调试环境,不能在生产环境使用。

总结

  1. 最推荐的方法是使用 HTTPS 进行局域网调试,浏览器对 HTTPS 环境支持摄像头和麦克风访问。
  2. 生成自签名证书 适用于开发调试,确保所有设备可以通过 HTTPS 访问。
  3. 使用 ngrok 创建一个 HTTPS 隧道也是非常便捷的方法。
  4. 在调试环境可以尝试关闭浏览器的安全限制,但仅限开发时使用。

如果你决定使用 HTTPS 而遇到问题,可以提供更多的错误信息或日志,我可以进一步帮助你。

标签:浏览器,无法访问,局域网,HTTPS,使用,172.19,http,server,调试
From: https://blog.csdn.net/sunyuhua_keyboard/article/details/143234782

相关文章

  • 【网络原理】HTTPS
      目录前言为什么要使用HTTPS?HTTPS是如果进行加密的1.对称加密2.非对称加密中间人攻击3.证书 中间人有没有可能篡改证书?中间人有没有可能整个调包证书?前言在上一篇中,我们讲解了什么是HTTP,但是在实际应用中,浏览器和服务器之间很少使用HTTP协议来进行通信。为......
  • 处理容器报错:[ERROR] .. Get “http://safeline-fvm/skynetinto“: dial tp: lookup s
    雷池社区版(WAF)是基于容器部署的在容器化应用的部署和运行过程中,我们常常会遇到各种报错信息。其中,形如“[ERROR]detect/skynet.go:114Get“http://safeline-fvm/skynetinto":dialtp:lookupsafeline-fvmon127.0.0.11:53:servermisbehaving”以及“panic:Get......
  • Netty、Go、Apache Tomcat、grpc-go、jetty、nghttp2、Apache Traffic Server是什么
    这些都是与网络编程和服务器应用相关的技术,下面我将分别简要介绍它们:Netty:Netty是一个异步事件驱动的网络应用程序框架,用于快速开发高性能、高可靠性的网络服务器和客户端程序。它支持多种协议,包括HTTP、HTTPS、FTP、SMTP等,广泛应用于游戏、移动、物联网、大数据等领域。......
  • HttpClient请求结果
    好的,你想要循环遍历对象列表,对每个GET请求执行HTTP请求,并检查响应状态码是否为200。如果状态码不是200,就打印出响应体。为了实现这个功能,可以使用HttpClient库,它更现代和灵活。以下是一个示例代码,演示如何实现上述需求:首先,添加依赖(如果你使用Maven),在pom.xml中添加HttpClient库......
  • IIS使用反向代理,解决路径包含特殊字符无法访问的问题
    环境:操作系统:WindowsServer2019IIS版本:10问题试用Nocobase的时候,遇到400BadRequest的报错。 直接访问的话,报错页面是非常常见的RuntimeError。诡异这个问题,在开发端(Windows11)的IIS中不会出现。同样的IIS版本。解决办法先说结论,时间比较赶的朋友直接试这个就可以......
  • 中间人攻击(https降级攻击)和iptables命令分析
    中间人攻击以下是一个简单的中间人攻击示例,结合ARP欺骗和流量修改:1.进行ARP欺骗首先,使用 arpspoof 进行ARP欺骗,将受害者的流量重定向到攻击者的机器上:sudoarpspoof-ieth0-t172.29.144.50172.29.144.12.启用IP转发确保IP转发已启用,以便攻击者可以将......
  • 为什么 Spring Boot 的微服务架构被称为“现代应用开发的曙光”?这种设计真的解决了传
    目录1.微服务架构为何被称为“现代应用开发的曙光”1.1单体架构的问题1.2微服务架构的诞生与发展1.3微服务架构的挑战2.SpringBoot在微服务中的角色2.1自动化配置与微服务开发2.2SpringCloud生态中的微服务3.微服务架构是否真的解决了传统单体架构中的所......
  • PbootCMS使用CDN或者https时后台功能异常跳转首页的解决办法
    在使用HTTPS或CDN时,PbootCMS的后台功能可能会因为环境差异而出现异常,特别是在开启关闭按钮、删除、以及保存排序等功能操作后会直接重定向到首页。这是由于PbootCMS在判断是否为HTTPS时存在问题。以下是详细的解决方案:问题描述在HTTPS或CDN环境下,PbootCMS的后台功......
  • HTTP和HTTPS在网络通信安全中有什么区别
    HTTP和HTTPS是互联网上两种主要的通信协议,他们的区别有:1.安全性和加密;2.认证和信任度;3.搜索引擎优化(SEO);4.性能和速度;5.兼容性和配置;6.数据保护法规遵从性;7.应用场景。HTTP(超文本传输协议)是互联网的基础通信协议,但它在传输数据时不提供加密或安全保护。相比之下,HTTPS(安全的HTTP)为......
  • [项目][boost搜索引擎#4] cpp-httplib使用 | log.hpp | 前端 | 测试及总结
    目录编写http_server模块1.引入cpp-httplib到项目中2.cpp-httplib的使用介绍3.正式编写http_server九、添加日志到项目中十、编写前端模块十一.详解传gitee十二、项目总结项目的扩展写在前面项目gitee已经上传啦(还是决定将学校和个人的gitee区分开来,所以......