当前位置: 首页 > article >正文

火狐浏览器设置秘籍:让https协议下的ws不加密时运行无阻(WebSocket connection HTTPS)

在这里插入图片描述

Uncaught (in promise) DOMException: Failed to construct ‘WebSocket’: An insecure WebSocket connection may not be initiated from a page loaded over HTTPS.

明确指出了一个常见的安全限制:当尝试从一个通过HTTPS加载的页面上发起一个不安全的(即非加密的,使用ws://而非wss://)WebSocket连接时,浏览器会阻止这个操作。这是因为HTTPS页面期望所有加载的资源(包括WebSocket连接)都应该是安全的,以防止中间人攻击等安全风险。如果页面通过HTTPS加载,但尝试与HTTP服务建立WebSocket连接,这可能会使HTTPS提供的安全保障失效。

解决方案

  • 使用WSS(WebSocket Secure)
    将WebSocket连接从ws://更改为wss://。这意味着WebSocket服务器需要支持TLS/SSL加密。

  • 火狐浏览器:
    配置network.websocket.allowInsecureFromHTTPS。

WSS配置

略。

火狐配置步骤

在这里插入图片描述

  1. 地址栏输入:about:config
  2. 查找:network.websocket.allowInsecureFromHTTPS
  3. 修改属性为:true

network.websocket.allowInsecureFromHTTPS

network.websocket.allowInsecureFromHTTPS 这个设置实际上并不是一个广泛认可或标准化的浏览器配置选项。在大多数现代浏览器(如Chrome、Firefox、Safari等)中,并没有直接名为 network.websocket.allowInsecureFromHTTPS 的设置来控制是否允许从HTTPS页面发起不安全的(即非wss://)WebSocket连接。

浏览器通常内置了安全策略,禁止从HTTPS页面加载不安全的资源,包括WebSocket连接,以保护用户免受潜在的安全威胁。这种策略是自动应用的,并且不需要用户或开发者进行额外的配置。然而,在某些特定的环境或应用程序中(如某些基于Chromium的嵌入式浏览器或特定框架中的浏览器组件),开发者或系统管理员可能会遇到需要自定义此类安全策略的情况。在这种情况下,他们可能会寻找或实现类似 network.websocket.allowInsecureFromHTTPS 的功能,但这通常是通过不同的方式实现的,比如:

  • 浏览器扩展或插件:某些浏览器扩展或插件可能提供了修改安全策略的能力,但这通常不是针对WebSocket的特定设置。
  • 浏览器配置文件:对于某些浏览器,特别是基于Chromium的浏览器,开发者或系统管理员可能可以修改浏览器的启动参数或使用特定的配置文件来覆盖默认的安全策略。但这通常涉及到复杂的配置和潜在的安全风险。
  • 服务器端代理:另一种常见的方法是使用服务器端代理来将不安全的WebSocket连接转换为安全的WebSocket连接(即wss://)。这样,即使原始WebSocket服务器不支持TLS/SSL,客户端也可以通过HTTPS页面安全地与之通信。
  • 本地开发环境:在本地开发环境中,开发者可能会使用HTTP服务器来测试WebSocket连接。在这种情况下,他们可能会暂时禁用浏览器的安全策略(例如,通过浏览器设置或扩展),但请注意,这种做法绝不应在生产环境中使用。
  • 自定义浏览器或WebView:在开发自定义浏览器或基于WebView的应用程序时,开发者可能具有更多的控制权来修改安全策略。然而,这通常需要深入了解浏览器的内部工作原理和安全性。

漏刻有时


http://www.kler.cn/news/295077.html

相关文章:

  • React Native中iOS工程从OC更换为swift
  • 压力测试知识总结
  • 网络学习-eNSP配置路由器
  • 【机器人工具箱Robotics Toolbox开发笔记(十四)】三连杆机器人直线轨迹规划仿真实例
  • 漫谈设计模式 [13]:命令模式
  • ES模块导入、导出学习笔记
  • 【网络安全】古典密码体制概述
  • Python--列表简介
  • js 写个 最简单的 chrome 插件,修改网页背景颜色
  • 退火吗?C#/WinForm演示退火算法
  • 手写 Vue Router 中的 Hash 模式和 History 模式
  • 反弹shell
  • 【Python报错已解决】 AttributeError: ‘move_to‘ requires a WebElement
  • Redis单机安装
  • 国开(电大)2024秋《文献检索与论文写作》综合练习2
  • 云服务器部署DB-GPT项目
  • 自动驾驶---Motion Planning之轨迹拼接
  • WIN11 ESP32 IDF + VSCODE 环境搭建[教程向]
  • 不会Excel怎么制作桑基图?用什么软件绘制比较好呢?推荐2款简单好用的图表制作工具
  • c++递推
  • 拉取ros2_control_demos存储库
  • List中常见的方法和五种遍历方式
  • windows下使用vscode编写运行以及调试C/C++
  • 基于STM32设计的ECG+PPG人体参数测量系统(华为云IOT)(217)
  • ROS1 + Realsense d455 固件安装+读取rostopic数据
  • nmon服务器监控工具使用
  • 请解释Java Web应用中的前后端分离是什么?它有哪些好处?什么是Java Web中的Servlet过滤器?它有什么作用?
  • ffmpeg的安装和使用教程
  • python--基础语法(1)
  • 《Ajax 是什么?如何在 HTML5 中使用》