admin 管理员组文章数量: 1184232
2024年3月19日发(作者:transport minister)
W
EBSOCKET
协议解析
WebSocket protocol 是HTML5一种新的协议。它是实现了浏览器
与服务器全双工通信(full-duplex)。这篇文章介绍了关于
Websocket 协议的相关信息,供大家参考。
现很多网站为了实现即时通讯,所用的技术都是轮询(polling)。轮询
是在特定的的时间间隔(如每1秒),由浏览器对服务器发出HTTP
request,然后由服务器返回最新的数据给客服端的浏览器。这种传
统的HTTP request 的模式带来很明显的缺点 – 浏览器需
要不断的向服务器发出请求,然而HTTP request 的header是非常
长的,里面包含的数据可能只是一个很小的值,这样会占用很多的带
宽。
而最比较新的技术去做轮询的效果是Comet – 用了AJAX。
但这种技术虽然可达到全双工通信,但依然需要发出请求。
在 WebSocket API,浏览器和服务器只需要要做一个握手的动作,
然后,浏览器和服务器之间就形成了一条快速通道。两者之间就直接
可以数据互相传送,改变了原有的B/S模式。
在这里是关于Websocket在 php 中的实现,这篇文章里,我主要
对websocket 协议进行一个简单的介绍。
Websocket 业务模型
浏览器端的websocket 请求一般是
// javacsript
var ws = new WebSocket("ws://127.0.0.1:4000");
= function(){
("succeed");
};
r = function(){
(“error”);
};
age = function(e){
(e);
}
当 new 一个 websocket 对象之后,就会向服务器发送一个 get
请求
这个请求是对摸个服务器的端口发送的,一般的话,会预先在服务器
将一个socket 绑定到一个端口上,客户端和服务器端在这个预定的
端口上通信(我这里绑定的就是 4000 端口,默认情况下,websocke
使用 80 端口)。
然后,在服务器端的socket监听到这个packet 之后就生成一个新
的 socket,将发送过来的数据中的 Sec-WebSocket-Key 解析出
来,然后按照把“Sec-WebSocket-Ke”加上一个魔幻
字符串
“258EAFA5-E914-47DA-95CA-C5AB0DC85B11”
。使用SHA-1加密,之后进行BASE-64编码,将结果做为
“Sec-WebSocket-Accept”头的值,返回给客户端。
客户端收到这个之后,就会将 通信协议 upgrade 到 websocket
协议。
然后就会在这个持久的通道下进行通信,包括浏览器的询问,服务器
的push,双方是在一个全双工的状态下相互通信。 切换后的
websocket 协议中的 数据传输帧的格式(此时不再使用html协议)
官方文档给出的说明:
直接看这个,谁都会有点头大: 我花了一幅图来简单的解释这个
frame 的结构。
各字段的解释:
FIN 1bit
表示信息的最后一帧,flag,也就是标记符
RSV 1-3 1bit each 以后备用的
默认都为 0
Opcode 4bit 帧类型,
Mask
1bit 掩码,是否加密数据,默认必须置为1
Payload len 7bit 数据的长度,当这个7 bit的数据 == 126
时,后面的2 个字节也是表示数 据长度,当它 ==
127 时,后面的 8 个字节表示数据长度Masking-key
1 or d 4];
}
在PHP中,当我们收到数据之后,按照这里的格式截取数据,并将
其按照这里的方法解析后就得到了浏览器发送过来的数据。 当我们
想把数据发送给浏览器时,也要按照这个格式组装frame。 这里是
我的方法:
function frame($s){
$a = str_split($s, 125);
if (count($a) == 1){
return "x81" . chr(strlen($a[0])) . $a[0];
}
$ns = "";
foreach ($a as $o){
$ns .= "x81" . chr(strlen($o)) . $o;
}
return $ns;
}
强行将要发送的数据分割成 125 Byte / frame,这样 playload len
只需要 7 bits。也就是直接将数据的长度的ascall码拼接上去,然
后后面跟上要发送的数据。 每一个 frame 前面加的
‘x81’ 用二进制就是: 1000 0001 1000 :
1 是 FIN
000 是三个备用的bit
0001 : 指的是 opcode 官方的解释:
可以设置 opcode的值,来告诉浏览器这个frame的数据属性。
以上就是精品学习网为大家提供的关于Websocket 协议的相关内
容,希望能够帮助到大家。
版权声明:本文标题:Websocket 协议解析 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.roclinux.cn/b/1710830818a575279.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论