美文网首页
WebSocket 机制 - 草稿

WebSocket 机制 - 草稿

作者: 芹菜斯_嘉丽 | 来源:发表于2017-09-29 13:30 被阅读0次

    WebSocket 是 HTML5 一种新的协议。它实现了浏览器与服务器全双工通信,能更好的节省服务器资源和带宽并达到实时通讯,它建立在 TCP 之上,同 HTTP 一样通过 TCP 来传输数据,但是它和 HTTP 最大不同是:

    1.WebSocket 是一种双向通信协议,在建立连接后,WebSocket 服务器和 Browser/Client Agent 都能主动的向对方发送或接收数据,就像 Socket 一样;

    2.WebSocket 需要类似 TCP 的客户端和服务器端通过握手连接,连接成功后才能相互通信。

       相对于传统 HTTP 每次请求-应答都需要客户端与服务端建立连接的模式,WebSocket 是类似 Socket 的 TCP 长连接的通讯模式,一旦 WebSocket 连接建立后,后续数据都以帧序列的形式传输。在客户端断开 WebSocket 连接或 Server 端断掉连接前,不需要客户端和服务端重新发起连接请求。在海量并发及客户端与服务器交互负载流量大的情况下,极大的节省了网络带宽资源的消耗,有明显的性能优势,且客户端发送和接受消息是在同一个持久连接上发起,实时性优势明显。

    WebSocket握手请求(使用http请求完成)

    清单 1.WebSocket 客户端连接报文

    GET /webfin/websocket/ HTTP/1.1

    Host: localhost

    Upgrade: websocket

    Connection: UpgradeSec-WebSocket-Key: xqBt3ImNzJbYqRINxEFlkg==

    Origin:http://localhost:8080

    Sec-WebSocket-Version: 13

    ////”Upgrade:websocket”参数值表明这是 WebSocket 类型请求,WebSocket-Key”是 WebSocket 客户端发送的一个 base64 编码的密文,要求服务端必须返回一个对应加/密的“Sec-WebSocket-Accept”应答,否则客户端会抛出“Error during WebSocket handshake”错误,并关闭连接。

    清单:2.WebSocket 服务端响应报文

    HTTP/1.1 101 Switching Protocols

    Upgrade: websocket

    Connection: Upgrade

    Sec-WebSocket-Accept: K7DJLdLooIwIG/MOpvWFB3y3FE8=

    ////“Sec-WebSocket-Accept”的值是服务端采用与客户端一致的密钥计算出来后返回客户端的,“HTTP/1.1 101 Switching Protocols”表示服务端接受 WebSocket 协议的客户端连接。

    webSocket 客户端实例

    // 创建一个Socket实例

    var socket = new WebSocket('ws://localhost:8080');//服务器地址

    // 打开Socket

    socket.onopen = function(event) {

    // 发送一个初始化消息

    socket.send('I am the client and I\'m listening!');

    // 监听消息

    socket.onmessage = function(event) {

    console.log('Client received a message',event);//???event.data???接收数据

    };

    // 监听Socket的关闭

    socket.onclose = function(event) {

    console.log('Client notified socket has closed',event);

    };

    // 关闭Socket....

    //socket.close()

    webSocket 规范定义了ws和wss两种url模式,ws 用于非加密连接,wss用于加密连接。

    相关文章

      网友评论

          本文标题:WebSocket 机制 - 草稿

          本文链接:https://www.haomeiwen.com/subject/uexlzttx.html