好程序员web前端分享WebSocket协议

好程序员web前端分享WebSocket协议,WebSocket协议简介html

  • WebSocket协议简介
  1. WebSocket是html5规范新引入的功能,用于解决浏览器与后台服务器双向通信的问题,使用WebSocket技术,后台能够随时向前端推送消息,以保证先后台状态统一,在传统的无状态HTTP协议中,这是“没法作到”的。

2. 在WebSocket出现以前,传统的服务端向浏览器推送消息的技术包括:ajax、flash、comet、java applet等。无一例外,这些技术使用的都是长轮循,即每隔一段时间去请求后台,以获取最新状态。长轮询方式容易实现,但效果也差,频繁盲目的调用后台,带来没必要要的开销,且实时性没法保障,后台出现更新,前端须要在下一次轮询时才知道。前端

3. WebSocket协议支持服务端与浏览器创建长链接,双方能够随时发送数据给对方,再也不是由客户端控制的一问一答的方式。在实现推送功能的时候,主要是由服务端给客户端发送数据。html5

4.之前的网站为了实现推送功能,使用的方法都是轮询。所谓的轮询就是在特定的时间间隔(例如1秒),由浏览器向服务器发出一个 Http request ,而后服务器返回最新的数据给客户端浏览器,从而给出一种服务端实时推送的假象。因为 Http Request 的 Header(请求头)很长,而传输的数据可能很短就只占一点点,每次请求消耗的带宽大部分都消耗在 Header 上。从网上资料得知后来还有改进的轮询方法叫作 Comet ,使用 Ajax 。但这种技术虽然可达到双向通讯。java

二.WebSocket原理程序员

  基于长轮循(polling)和websocket推送的浏览器(browser)和服务端(Server)的交互对比图以下所示:web

  因为WebSocket协议创建在http协议的基础之上,所以两者有不少的相似之处。事实上,在使用websocket协议时,浏览器与服务端最开始创建的仍是http链接,以后再将协议从http转换成websocket,协议转换的过程称之为握手(handshake),表示服务端与客户端都赞成创建websocket协议。须要注意的是,因为websocket是新的协议,须要浏览器和web服务端都支持的状况下,才能创建链接成功。正常状况下,链接在创建的时候,浏览器向服务端发送一个HTTP请求,经过包含一些额外信息,代表其但愿将协议从HTTP转换成WebSocket。这个额外信息实际上就是增长了一个请求头Update,以下所示:ajax

熟悉 HTTP 的童鞋可能发现了,这段相似 HTTP 协议的握手请求中,多了这么几个东西。浏览器

这个就是 WebSocket 的核心了,告诉 Apache 、 Nginx 等服务器:注意啦,我发起的请求要用 WebSocket 协议,快点帮我找到对应的助理处理~而不是那个老土的 HTTP。服务器

首先, Sec-WebSocket-Key 是一个 Base64 encode 的值,这个是浏览器随机生成的,告诉服务器:泥煤,不要忽悠我,我要验证你是否是真的是 WebSocket 助理。websocket

 

而后, Sec_WebSocket-Protocol 是一个用户定义的字符串,用来区分同 URL 下,不一样的服务所须要的协议。简单理解:今晚我要服务A,别搞错啦~

 

最后, Sec-WebSocket-Version 是告诉服务器所使用的 WebSocket Draft (协议版本),在最初的时候,WebSocket 协议还在 Draft 阶段,各类奇奇怪怪的协议都有,并且还有不少期奇奇怪怪不一样的东西,什么 Firefox 和 Chrome 用的不是一个版本之类的,当初 WebSocket 协议太多但是一个大难题。不过如今还好,已经定下来啦~你们都使用同一个版本: 服务员,我要的是13岁的噢→_→

 

而后服务器会返回下列东西,表示已经接受到请求, 成功创建 WebSocket 啦!

 

能够在如下网址看到目前支持webscoket协议的主流浏览器和版本:

  支持html5的浏览器,通常都会提供一个内置的js对象Websocket ,开发者利用这个对象就能够与服务端创建websocket链接。特别的在FireFox中,这个对象为在Firefox中为MozWebSocket。

  能够经过如下js代码检测一个浏览器是否支持websocket

Websocket对象还提供了几个回调方法

//链接建立成功时被回调

myWebSocket.onopen = function(evt) { alert("Connection open ..."); };

//收到服务端的消息时被回调

myWebSocket.onmessage = function(evt) { alert( "Received Message: " + evt.data); };

//链接关闭时被回调

myWebSocket.onclose = function(evt) { alert("Connection closed."); };    

相关文章
相关标签/搜索