WebSocket 是 HTML5 提供的一种在单个TCP连接上进行全双工通讯的协议。

WebSocket 使得客户端和服务端通讯,数据交换更加简单,而且允许服务端主动向客户端发送数据。在WebSocket API 中,浏览器和服务器只需要完成一次握手,就可以建立一条持久性的通道,进行数据的双向传输。

现在,很多的网站的推送技术是依然使用ajax轮询。轮询是在一定时间间隔后,由浏览器发送请求到服务器,然后获得服务器返回的最新的数据。这种方式,明显的缺点就是浏览器需要不断地发送请求,而请求可能包含较长的头部,真正有效的只有一小部分,造成了宽带资源的浪费。一直请求加重了服务端的压力。

HTML5定义的WebSocket协议,更更好的节省宽带和服务器资源,能够进行实时通讯,而且是服务端可控的,当数据没有更新时,可以不用传送数据。

浏览器通过JavaScript向服务器发送建立WebSocket链接的请求,链接建立后,服务器和浏览器端就可以通过TCP连接直接交换数据了。

当获取WebSocket连接后,可以通过 send() 方法向服务器发送数据,并通过 onmessage 事件来监听服务端返回的数据。

相关的API:

1、创建 WebSocket 对象:new WebSocket(url [, protocol ])

 const socket = new WebSocket('ws://localhost:2333');

关于url,MDN 说应该使用 wss:// 模式。我这是使用vscode 本地连接可以使用 ws://

MDN原文:MDN传送门

The URL to which to connect; this should be the URL to which the WebSocket server will respond. This should use the URL scheme wss://, although some software may allow you to use the insecure ws:// for local connections.

第二个可选参数,规定可接受的子协议。一个服务器可以实施多个WebSocket子协议,比如希望一个服务器根据指定的协议处理不同类型的交互。不指定则为空字符串。

2、onopen 监听连接建立时执行。

         // 指定链接成功后的回调
socket.onopen = function () {
console.log('这是连接成功后的回调')
} socket.addEventListener('open', function(event) {
console.log('链接上了 == ', event)
// socket.send(1)
})

3、onmessage 监听服务端返回的数据,然后执行回调函数。

         // 指定从服务器接收消息时的回调
socket.onmessage = function(event) {
console.log('onmessage == ', event.data)
} socket.addEventListener('message', function(event) {
console.log('message from server == ', event.data)
})

4、onerror 监听发生错误时的情况。

         // 指定链接失败后的回调
socket.onerror = function(event) {
console.log('链接错误 == ', event)
} socket.addEventListener('error', function(event) {
console.log('addEventListener error == ', event)
})

5、onclose 监听WebSocket关闭。

         // 指定链接关闭后的回调
socket.onclose = function() {
alert('链接已关闭,后续操作无效')
} socket.addEventListener('close', function() {
console.log('close link')
})

on事件的执行会先于对应的 addEventListener。

6、WebSocket 还有几个只读属性。

             // 用于返回服务器端选中的子协议的名字;这是一个在创建WebSocket 对象时,在参数protocols中指定的字符串
console.log( 'socket protocol == ', socket.protocol )
// 返回当前 WebSocket 的链接状态。
// 0:连接中;1:已连接且可通讯;2:正在关闭;3:连接已关闭或没有连接成功
console.log( 'socket readyState == ', socket.readyState )
// 构造函数创建WebSocket实例对象时URL的绝对路径。
console.log( 'socket url == ', socket.url )
// 返回服务器已选择的扩展值。目前,链接可以协定的扩展值只有空字符串或者一个扩展列表。
console.log( 'socket extensions == ', socket.extensions )
// 返回已经被send()方法放入队列中但还没有被发送到网络中的数据的字节数。一旦队列中的所有数据被发送至网络,则该属性值将被重置为0。但是,若在发送过程中连接被关闭,则属性值不会重置为0。如果你不断地调用send(),则该属性值会持续增长。
console.log( 'socket bufferedAmount == ', socket.bufferedAmount )

更详细点击查看MDN

WebSocket--客户端的更多相关文章

  1. 【转】SocketRocket:iOS WebSocket客户端开源框架

    原文网址:http://blog.csdn.net/zmp1123/article/details/44015507 WebSocket: WebSocket通信协议实现的是基于浏览器的原生socke ...

  2. 火币网行情获取的websocket客户端

    从验证结果看应该是网络关闭了,不过程序写的不错,可以作为其它websocket客户端的测试程序 # !/usr/bin/env python # -*- coding: utf-8 -*- # aut ...

  3. HTTPS请求HTTP接口被浏览器阻塞,python实现websocket客户端,websocket服务器,跨域问题,dwebsocket,https,拦截,服务端

    HTTPS请求HTTP接口被浏览器阻塞,python实现websocket客户端,websocket服务器,跨域问题,dwebsocket,https,拦截,服务端 发表时间:2020-03-05 1 ...

  4. netty系列之:使用netty搭建websocket客户端

    目录 简介 浏览器客户端 netty对websocket客户端的支持 WebSocketClientHandshaker WebSocketClientCompressionHandler netty ...

  5. JAVA实现websocket客户端

    pom依赖 <dependency> <groupId>org.java-websocket</groupId> <artifactId>Java-We ...

  6. Netty学习笔记(六) 简单的聊天室功能之WebSocket客户端开发实例

    在之前的Netty相关学习笔记中,学习了如何去实现聊天室的服务段,这里我们来实现聊天室的客户端,聊天室的客户端使用的是Html5和WebSocket实现,下面我们继续学习. 创建客户端 接着第五个笔记 ...

  7. node.js中ws模块创建服务端和客户端,网页WebSocket客户端

    首先下载websocket模块,命令行输入 npm install ws 1.node.js中ws模块创建服务端 // 加载node上websocket模块 ws; var ws = require( ...

  8. 用JAVA分别实现WebSocket客户端与服务端

    最近公司在搞一个项目刚好需要用到WebSocket技术来实现实时数据的传输,因为之前也没接触过,所以捣鼓了好些天,最近恰巧有空就写写.有误的地方还请大牛们能及时指正. 项目背景:基于spring+sp ...

  9. netty实现websocket客户端(附:测试服务端代码)

    1,客户端启动类 package test3; import io.netty.bootstrap.Bootstrap; import io.netty.buffer.Unpooled; import ...

  10. 原创:Javascript Websocket客户端封装

    调试中,马马虎虎能用var LeesWebSocket = function (options) { this.defaults = { host: "127.0.0.1", po ...

随机推荐

  1. ELK 框架整体流程编写 以及logstash脚本编写

    Elasticsearch Elasticsearch 是一个实时的分布式搜索和分析引擎,它可以用于全文搜索,结构化搜索以及分析.它是一个建立在全文搜索引擎 Apache Lucene 基础上的搜索引 ...

  2. re2c安装

    wget  https://kojipkgs.fedoraproject.org//packages/re2c/1.1.1/3.fc31/src/re2c-1.1.1-3.fc31.src.rpm 解 ...

  3. Python字典(Dictionary)update()方法

    原文连接:https://www.runoob.com/python/att-dictionary-update.html Python字典(dictionary)update()函数把字典dict2 ...

  4. 你真的了解nginx重定向URI?-rewrite和alias指令

    未经允许不得转载!最近发现有博主转载我的文章,并没有跟我打招呼,也没有注明出处!!!! 熟悉Nginx的同学都知道Nginx可以用来做负载均衡和反向代理,非常好用.做前后端分离也是非常的方便. 今天我 ...

  5. vue-cli安装以及创建一个简单的项目(二)(vuex使用、发行一个简单的app)

    1.vuex的使用 vuex是vue的状态管理中心,vuex来保存我们需要管理的状态值,值一旦被修改,所有引用该值的地方就会自动更新,常用于: 1.多个视图依赖同一状态(l例:菜单导航) 2.来自不同 ...

  6. MySQL for OPS 05:日志管理

    写在前面的话 日志是作为用户排查服务问题的重要依据,在 MySQL 中日志可以分为几类,各自产生着不同的作用.如 error log / bin log / slow log 等.很多时候优化数据库的 ...

  7. 【01】Nginx:编译安装/动态添加模块

    写在前面的话 说起 Nginx,别说运维,就是很多开发人员也很熟悉,毕竟如今已经 2019 年了,Apache 更多的要么成为了历史,要么成为了历史残留. 我们在提及 Nginx 的时候,一直在强调他 ...

  8. 开发技术--Python核心技术B

    开发|Python核心技术B B篇,主要介绍Python的自定义函数,匿名函数,面向对象,模块化. 由于不涉及基础的知识,我会将重难点加以解释. 前言 目前所有的文章思想格式都是:知识+情感. 知识: ...

  9. DjangoForm 提交验证

    用户提交数据的验证 1.创建模版 -- class LoginForm(forms.Form):.... 2.将请求交给模版,创建一个对象 -- obj = LoginForm(request.POS ...

  10. Django的版本坑

    Django2.x与1.x版本之间的坑 App模块中models.py django2.x是中reverse使用方法 from django.urls import reverse ForeignKe ...