webSocket原理

webSocket三次握手

**1.客户端发送WebSocket握手请求:**当客户端想要建立WebSocket连接时,他会发送一个HTTP请求到服务器,HTTP协议版本不能低于1.1,GET请求到服务器,这个请求通常称为握手请求,其中包含一些特定的头信息,表示客户端希望升级到WebSocket协议

GET / HTTP/1.1

Upgrade: websocket

Connection:Upgrade

Host: example.com

Origin: [http://example.com

Sec-WebSocket-Key: sN9cRrP/n9NdMgdcy2VJFQ==

Sec-WebSocket-Version:13

**2.服务器响应握手请求:**服务器接收客户端的握手请求后,会进行一些协议验证,验证后会向客户端发送一个HTTP响应,响应中包含了一些头部信息,其中比较重要的是

验证协议和请求方法

WebSocket协议是基于HTTP1.1的,并且WebSocket协议规定了在初始握手阶段,客户端向服务器发送的请求方法必须是GET

检查头信息

检查请求头的Upgrade,和Connection

生成Sec-WebSocket-key

服务器收到客户端传来的Sec-webSocket-key之后,将其与固定的UID进行拼接,经过sha-1摘要计算和Base64编码,生成新的Base64编码值作为响应头的sec-websocket-accept字段

HTTP/1.1 101 Switching Protocols

Upgrade: websocket

Connection:Upgrade

Sec-WebSocket-Accept: fFBooB7FAkLlXgRSz0BT3v4hq5s=

Sec-WebSocket-Location: ws://example.com/

返回握手响应报文,他会返回HTTP响应,状态码为101,表示服务器理解客户端请求,需要客户端采取不同的协议来完成请求

3.客户端验证握手响应

检查状态码

客户端接收服务器的握手响应后,首先检查响应状态码是否为101

检查响应头信息

如upgrade和connection,以确保服务器升级到了websocket协议并建立持久链接

验证sec-websocket-accept头信息

客户端接收到服务器的握手响应后,将获取到的Sec-WebSocket-Accept与自己的Sec-Websocket-Key进行验证,如果两者相等,则验证通过,发送确认握手成功报文,否则,验证失败

4.确认握手并建立WebSocket连接

确认握手成功,客户端将连接从HTTP协议升级成webSocket协议,客户端和服务器之间的通信将采用webSocket协议进行双向实时数据传输

需要注意的是,WebSocket握手成功并升级协议后,后续的数据传输将不再遵循HTTP的请求-响应模型,而是使用WebSocket协议的帧结构进行数据交换

相关推荐
运维Z叔1 小时前
云安全 | AWS S3存储桶安全设计缺陷分析
android·网络·网络协议·tcp/ip·安全·云计算·aws
weixin_456732591 小时前
网络-内核是如何与用户进程交互
网络·交互
陈大爷(有低保)2 小时前
UDP Socket聊天室(Java)
java·网络协议·udp
爱吃涮毛肚的肥肥(暂时吃不了版)2 小时前
计算机网络34——Windows内存管理
网络·计算机网络·udp
码哝小鱼3 小时前
firewalld封禁IP或IP段
linux·网络
sec0nd_3 小时前
1网络安全的基本概念
网络·安全·web安全
青柠视频云4 小时前
青柠视频云——视频丢包(卡顿、花屏、绿屏)排查
服务器·网络·音视频
网安CILLE4 小时前
2024年某大厂HW蓝队面试题分享
网络·安全·web安全
沐风ya4 小时前
Reactor介绍,如何从简易版本的epoll修改成Reactor模型(demo版本代码+详细介绍)
网络
SUGERBOOM4 小时前
【网络安全】网络基础第一阶段——第一节:网络协议基础---- OSI与TCP/IP协议
网络·网络协议·web安全