Websocket 协议解析.docx

上传人:b****6 文档编号:3874083 上传时间:2022-11-26 格式:DOCX 页数:5 大小:291.15KB
下载 相关 举报
Websocket 协议解析.docx_第1页
第1页 / 共5页
Websocket 协议解析.docx_第2页
第2页 / 共5页
Websocket 协议解析.docx_第3页
第3页 / 共5页
Websocket 协议解析.docx_第4页
第4页 / 共5页
Websocket 协议解析.docx_第5页
第5页 / 共5页
亲,该文档总共5页,全部预览完了,如果喜欢就下载吧!
下载资源
资源描述

Websocket 协议解析.docx

《Websocket 协议解析.docx》由会员分享,可在线阅读,更多相关《Websocket 协议解析.docx(5页珍藏版)》请在冰豆网上搜索。

Websocket 协议解析.docx

Websocket协议解析

Websocket协议解析

 

WebSocketprotocol是HTML5一种新的协议。

它是实现了浏览器与服务器全双工通信(full-duplex)。

这篇文章介绍了关于Websocket协议的相关信息,供大家参考。

现很多网站为了实现即时通讯,所用的技术都是轮询(polling)。

轮询是在特定的的时间间隔(如每1秒),由浏览器对服务器发出HTTPrequest,然后由服务器返回最新的数据给客服端的浏览器。

这种传统的HTTPrequest的模式带来很明显的缺点–浏览器需要不断的向服务器发出请求,然而HTTPrequest的header是非常长的,里面包含的数据可能只是一个很小的值,这样会占用很多的带宽。

而最比较新的技术去做轮询的效果是Comet–用了AJAX。

但这种技术虽然可达到全双工通信,但依然需要发出请求。

在WebSocketAPI,浏览器和服务器只需要要做一个握手的动作,然后,浏览器和服务器之间就形成了一条快速通道。

两者之间就直接可以数据互相传送,改变了原有的B/S模式。

在这里是关于Websocket在php中的实现,这篇文章里,我主要对websocket协议进行一个简单的介绍。

Websocket业务模型

浏览器端的websocket请求一般是

//javacsript

varws=newWebSocket("ws:

//127.0.0.1:

4000");

ws.onopen=function(){

console.log("succeed");

};

ws.onerror=function(){

console.log(“error”);

};

ws.onmessage=function(e){

console.log(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,也就是标记符

RSV1-3    1biteach以后备用的默认都为0

Opcode    4bit帧类型,

Mask       1bit掩码,是否加密数据,默认必须置为1

Payloadlen 7bit数据的长度,当这个7bit的数据==126时,后面的2个字节也是表示数  据长度,当它==127时,后面的8个字节表示数据长度Masking-key   1ord4];

}

在PHP中,当我们收到数据之后,按照这里的格式截取数据,并将其按照这里的方法解析后就得到了浏览器发送过来的数据。

当我们想把数据发送给浏览器时,也要按照这个格式组装frame。

这里是我的方法:

functionframe($s){

$a=str_split($s,125);

if(count($a)==1){

return"\x81".chr(strlen($a[0])).$a[0];

}

$ns="";

foreach($aas$o){

$ns.="\x81".chr(strlen($o)).$o;

}

return$ns;

}

强行将要发送的数据分割成125Byte/frame,这样playloadlen只需要7bits。

也就是直接将数据的长度的ascall码拼接上去,然后后面跟上要发送的数据。

每一个frame前面加的‘\x81’用二进制就是:

100000011000:

1是FIN

000是三个备用的bit

0001:

指的是opcode官方的解释:

可以设置opcode的值,来告诉浏览器这个frame的数据属性。

以上就是精品学习网为大家提供的关于Websocket协议的相关内容,希望能够帮助到大家。

 

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 高中教育 > 语文

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1