WebSocket(WS)协议系列(三)加密

news/2025/3/10 17:01:13/

平时看到两种形式:ws 和 wss。他们有什么联系吗?

ws 和 wss 都是 WebSocket 协议的两种形式,它们分别代表了不同的传输层协议。它们之间的主要区别在于加密和安全性。

  1. ws: WebSocket 协议
    ws 代表 WebSocket 协议(不加密的)。它基于 HTTP 协议的 升级请求(HTTP Upgrade),并建立一个持久化的、双向的通信通道。

ws 使用的端口通常是 80(与普通 HTTP 相同),这意味着它不会对数据进行加密。

典型的 URL:

ws://example.com/socket

特点:

数据是 明文传输 的,不提供任何加密。
适用于不需要安全保护或在局域网内使用的应用。
对于开放网络或公网上传输的敏感数据,不推荐使用 ws,因为它容易受到 中间人攻击(MITM) 等网络攻击的影响。

  1. wss: WebSocket Secure 协议
    wss 代表 WebSocket 协议的 加密版本(即 WebSocket Secure)。它是通过 SSL/TLS 协议加密的 WebSocket 连接,相当于 HTTPS 协议与 HTTP 协议的关系。

wss 使用的端口通常是 443,与 HTTPS 协议相同,保证了数据传输过程中的安全性。

典型的 URL:

wss://example.com/socket

特点:

数据是通过 加密传输 的,使用 SSL/TLS 协议提供 端到端的加密保护,有效防止 窃听 和 中间人攻击。
它通常用于需要传输 敏感数据 或 保护隐私的应用,如在线聊天、金融应用、实时交易系统等。
wss 协议与 HTTPS 协议相似,确保连接建立时服务器和客户端之间的通信是安全的。

特性ws:// (WebSocket)wss:// (WebSocket Secure)
加密不加密(明文传输)加密(使用 SSL/TLS)
端口默认端口:80默认端口:443
用途非安全环境或局域网使用安全环境(互联网)
适用场景开放环境中不敏感的通信需要加密的通信,如金融、隐私保护场景
安全性容易受到中间人攻击(MITM)防止窃听和中间人攻击

为什么要使用 wss 而不是 ws?

安全性:wss 加密了数据传输,避免了数据被第三方窃取或篡改,特别是在不安全的网络环境(如公共 Wi-Fi 或互联网)中,wss 是必不可少的。
身份验证和数据保护:如果 WebSocket 用于传输敏感数据(如用户的个人信息或支付信息),wss 是强制性的,确保只有授权的客户端和服务器可以互相交换数据。
浏览器支持:大部分现代浏览器在访问加密网站时会提示用户是否信任该网站的 SSL 证书,而 ws 可能会被视为不安全的连接。


http://www.ppmy.cn/news/1578133.html

相关文章

小迪安全-27-php开发,tp框架,路由访问,对象操作,内置过滤,核心漏洞

下载一个thinkphp的框架 thinkphp就是一个mvc架构 5.0.2即可 绑定一下域名到 就可以访问了 而输出的地方在这里 而这种框架有使用手册和规范操作,代码写法也跟原生不一样,例如数据库配置 只需要在这里输入好即可,都不用自己再去写链接 这是…

Vue项目通过内嵌iframe访问另一个vue页面,获取token适配后端鉴权(以内嵌若依项目举例)

1. 改造子Vue项目进行适配(ruoyi举例) (1) 在路由文件添加需要被外链的vue页面配置 // 若依项目的话是 router/index.js文件 {path: /contrast,component: () > import(/views/contrast/index),hidden: true },(2) 开放白名单 // 若依项目的话是 permission.js 文件 cons…

deepseek在pycharm中的配置和简单应用

对于最常用的调试python脚本开发环境pycharm,如何接入deepseek是我们窥探ai代码编写的第一步,熟悉起来总没坏处。 1、官网安装pycharm社区版(免费),如果需要安装专业版,需要另外找破解码。 2、安装Ollama…

vue3中子组件获取父组件的name,父组件不做修改动作

在 Vue 3 中,子组件若要获取父组件的 name,且父组件不做额外操作,可以借助 getCurrentInstance 来实现。getCurrentInstance 方法能获取当前组件实例,进而访问其父组件实例及其属性。 示例代码 父组件(ParentComponent…

人工智能里的深度学习指的是什么?

深度学习(Deep Learning, 简称DL)是机器学习领域的一个重要分支,它通过构建和训练深层神经网络模型,从大量数据中自动学习和提取特征,以实现复杂任务的自动化处理和决策。以下是关于深度学习的详细介绍: 一…

阿里发布新开源视频生成模型Wan-Video,支持文生图和图生图,最低6G就能跑,ComFyUI可用!

Wan-Video 模型介绍:包括 Wan-Video-1.3B-T2V 和 Wan-Video-14B-T2V 两个版本,分别支持文本到视频(T2V)和图像到视频(I2V)生成。14B 版本需要更高的 VRAM 配置。 Wan2.1 是一套全面开放的视频基础模型&…

Qt:多线程

目录 初识Qt多线程 QThread常用API QThread的使用 Qt中的锁 条件变量和信号量 初识Qt多线程 Qt 多线程 和 Linux 中的线程本质是一个东西 Linux 中学过的 多线程 APl,Linux 系统提供的 pthread 库 Qt 中针对系统提供的线程 API 重新封装了 C11 中,…

【Conda】Windows安装conda/Anaconda环境

安装conda并配置powershell 访问该网址,下载安装即可: Anaconda下载 安装完成后,打开Anaconda,并访问Powershell Prompt 弹出Windows Terminal,并正常进入Conda 【非必须】如果不是通过Windows Terminal打开&#x…