ImageVerifierCode 换一换
格式:DOCX , 页数:5 ,大小:291.15KB ,
资源ID:3874083      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/3874083.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(Websocket 协议解析.docx)为本站会员(b****6)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

Websocket 协议解析.docx

1、Websocket 协议解析Websocket 协议解析WebSocket protocol 是HTML5一种新的协议。它是实现了浏览器与服务器全双工通信(full-duplex)。这篇文章介绍了关于Websocket 协议的相关信息,供大家参考。现很多网站为了实现即时通讯,所用的技术都是轮询(polling)。轮询是在特定的的时间间隔(如每1秒),由浏览器对服务器发出HTTP request,然后由服务器返回最新的数据给客服端的浏览器。这种传统的HTTP request 的模式带来很明显的缺点 – 浏览器需要不断的向服务器发出请求,然而HTTP request 的header是非

2、常长的,里面包含的数据可能只是一个很小的值,这样会占用很多的带宽。而最比较新的技术去做轮询的效果是Comet – 用了AJAX。但这种技术虽然可达到全双工通信,但依然需要发出请求。在 WebSocket API,浏览器和服务器只需要要做一个握手的动作,然后,浏览器和服务器之间就形成了一条快速通道。两者之间就直接可以数据互相传送,改变了原有的B/S模式。在这里是关于Websocket在 php 中的实现,这篇文章里,我主要对websocket 协议进行一个简单的介绍。Websocket 业务模型浏览器端的websocket 请求一般是/ javacsriptvar ws = new

3、WebSocket("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 绑定到一个端口上,客户端和服务器端在这个预定的端口

4、上通信(我这里绑定的就是 4000 端口,默认情况下,websocke 使用 80 端口)。然后,在服务器端的socket监听到这个packet 之后就生成一个新的 socket,将发送过来的数据中的 Sec-WebSocket-Key 解析出来,然后按照把“Sec-WebSocket-Ke”加上一个魔幻字符串“258EAFA5-E914-47DA-95CA-C5AB0DC85B11”。使用SHA-1加密,之后进行BASE-64编码,将结果做为“Sec-WebSocket-Accept”头的值,返回给客户端。客户端收到这个

5、之后,就会将 通信协议 upgrade 到 websocket 协议。然后就会在这个持久的通道下进行通信,包括浏览器的询问,服务器的push,双方是在一个全双工的状态下相互通信。 切换后的websocket 协议中的 数据传输帧的格式(此时不再使用html协议) 官方文档给出的说明:直接看这个,谁都会有点头大: 我花了一幅图来简单的解释这个 frame 的结构。各字段的解释:FIN              1bit 表示信息的最后一帧,flag,也就是标记符RSV 1-3       &nbs

6、p;1bit each 以后备用的 默认都为 0Opcode         4bit 帧类型,Mask              1bit 掩码,是否加密数据,默认必须置为1Payload len   7bit 数据的长度,当这个7 bit的数据 = 126 时,后面的2 个字节也是表示数     据长度,当它 = 127 时,后面的 8 个字节表示数据长度Masking-key      1 or d 4;在PHP中,当我

7、们收到数据之后,按照这里的格式截取数据,并将其按照这里的方法解析后就得到了浏览器发送过来的数据。 当我们想把数据发送给浏览器时,也要按照这个格式组装frame。 这里是我的方法:function frame($s)$a = str_split($s, 125);if (count($a) = 1)return "x81" . chr(strlen($a0) . $a0;$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 是 FIN000 是三个备用的bit0001 : 指的是 opcode 官方的解释:可以设置 opcode的值,来告诉浏览器这个frame的数据属性。以上就是精品学习网为大家提供的关于Websocket 协议的相关内容,希望能够帮助到大家。

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

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