博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
WebSocket浅谈
阅读量:6565 次
发布时间:2019-06-24

本文共 2162 字,大约阅读时间需要 7 分钟。

WebSocket是HTML5开始提供的一种在单个 TCP 连接上进行全双工通讯的协议。
在WebSocket API中,浏览器和服务器只需要做一个握手的动作,然后,浏览器和服务器之间就形成了一条快速通道。两者之间就直接可以数据互相传送。
浏览器通过 JavaScript 向服务器发出建立 WebSocket 连接的请求,连接建立以后,客户端和服务器端就可以通过 TCP 连接直接交换数据。
当你获取 Web Socket 连接后,你可以通过 send() 方法来向服务器发送数据,并通过 onmessage 事件来接收服务器返回的数据。
以下 API 用于创建 WebSocket 对象。
var Socket = new WebSocket(url, [protocol] );
以上代码中的第一个参数 url, 指定连接的 URL第二个参数 protocol 是可选的,指定了可接受的子协议。
 
WebSocket 属性
以下是 WebSocket 对象的属性。假定我们使用了以上代码创建了 Socket 对象:
 
属性  描述
Socket.readyState 
只读属性 readyState 表示连接状态,可以是以下值:
0 - 表示连接尚未建立。
1 - 表示连接已建立,可以进行通信。
2 - 表示连接正在进行关闭。
3 - 表示连接已经关闭或者连接不能打开。
Socket.bufferedAmount   只读属性 bufferedAmount 已被 send() 放入正在队列中等待传输,但是还没有发出的 UTF-8 文本字节数。
 
WebSocket 事件
以下是 WebSocket 对象的相关事件。假定我们使用了以上代码创建了 Socket 对象:
 
事件     事件处理程序   描述
open     Socket.onopen  连接建立时触发
message  Socket.onmessage   客户端接收服务端数据时触发
error     Socket.onerror  通信发生错误时触发
close     Socket.onclose   连接关闭时触发
 
WebSocket 方法
以下是 WebSocket 对象的相关方法。假定我们使用了以上代码创建了 Socket 对象:
 
方法     描述
Socket.send()  使用连接发送数据
Socket.close() 关闭连接
 
WebSocket 实例
WebSocket 协议本质上是一个基于 TCP 的协议
为了建立一个 WebSocket 连接,客户端浏览器首先要向服务器发起一个 HTTP 请求,这个请求和通常的 HTTP 请求不同,包含了一些附加头信息,其中附加头信息"Upgrade: WebSocket"表明这是一个申请协议升级的 HTTP 请求,服务器端解析这些附加的头信息然后产生应答信息返回给客户端,客户端和服务器端的 WebSocket 连接就建立起来了,双方就可以通过这个连接通道自由的传递信息,并且这个连接会持续存在直到客户端或者服务器端的某一方主动的关闭连接。
客户端的 HTML 和 JavaScript
目前大部分浏览器支持 WebSocket() 接口,你可以在以下浏览器中尝试实例: Chrome, Mozilla, Opera 和 Safari。
websocket.html 文件内容
<!DOCTYPE HTML>
<html>
   <head>
   <meta charset="utf-8">
   <title>websocket</title>
      <script type="text/javascript">
         function WebSocketTest(){
            if ("WebSocket" in window){
               alert("您的浏览器支持 WebSocket!");
               // 打开一个 web socket
               var ws = new WebSocket("ws://localhost:9998/echo");
               ws.onopen = function(){
                  // Web Socket 已连接上,使用 send() 方法发送数据
                  ws.send("发送数据");
                  alert("数据发送中...");
               };
               ws.onmessage = function (evt){
                  var received_msg = evt.data;
                  alert("数据已接收...");
               };
               ws.onclose = function(){
                  // 关闭 websocket
                  alert("连接已关闭...");
               };
            }else{
               // 浏览器不支持 WebSocket
               alert("您的浏览器不支持 WebSocket!");
            }
         }
      </script>
   </head>
   <body>
      <div id="sse">
         <a href="javascript:WebSocketTest()">运行 WebSocket</a>
      </div>
   </body>
</html>
 希望对你有所帮助,结一段小善缘:小就是不深不浅,善就是天性使然,缘就是聚合离散。

转载于:https://www.cnblogs.com/sunyuweb/p/9341190.html

你可能感兴趣的文章
中文latex去掉图片描述
查看>>
ASP.NET MVC使用Bootstrap系统(2)——使用Bootstrap CSS和HTML元素
查看>>
【Scala】Scala-调用Java-集合
查看>>
【Kafka】Kafka-数据倾斜问题-参考资料-解决方案
查看>>
c# emit 实现类的代理
查看>>
Cookie的简单实用
查看>>
id: cannot find name for user ID xxx处理办法
查看>>
LeetCode - 776. Split BST
查看>>
JSP页面中验证码的调用方法
查看>>
大数乘法
查看>>
Apache Spark 2.2中基于成本的优化器(CBO)(转载)
查看>>
读DEDECMS找后台目录有感
查看>>
spring-boot2
查看>>
ASP .Net Core系统部署到SUSE 16 Linux Enterprise Server 12 SP2 64 具体方案
查看>>
JDK1.8源码(三)——java.lang.String 类
查看>>
微服务实战(六):选择微服务部署策略
查看>>
Spring使用环境变量控制配置文件加载(转)
查看>>
nginx调用PHP有sock方式和端口方式
查看>>
windows 启用远程服务
查看>>
CSS实现元素居中原理解析
查看>>