HTML5 WebSocket 权威指南 学习一 (第二章 WebSocket API)

WebSocket 协议两种URL方案
  ws 客户端和服务器之间的非加密流量
  wss 客户端和服务器之间的加密流量

WebSocket Secure 表示使用传输层安全性(SSL)的WebSocket连接 采用HTTPS安全机制来保证HTTP连接安全

1.WebSocket 的构造函数

var ws = new WebSocket("ws://www.websocket.org");

  

2.WebSocket 对象调度4个不同的事件 open message error close
  处理方法:和所有WebAPI一样 用on<事件名称> 处理程序属性
a.WebSocket事件 open
  定义:一旦服务器相应了WebSocket的连接请求,open事件触发并建立一个连接。open事件对应的回调函数称为onopen
代码:

var ws = new WebSocket("ws://www.websocket.org");
ws.onopen = function(){
  console.log("connect success");
};

意义:open事件触发时 WebSocket已经准备好发送和接受数据 应用程序接收到open事件 那么可以确定WebSocket服务器成功处理了连接请求,并且同意与之通信。

b.WebSocket事件 message
  定义:message事件在接收到消息时触发,对应了该事件的回调函数是onmessage
代码:

ws = new WebSocket("ws://127.0.0.1:2346");
ws.onopen = function() {
  alert("连接成功");
  ws.send(‘tom‘);
  alert("给服务端发送一个字符串:tom");
};
ws.onmessage = function(e) {
  alert("收到服务端的消息:" + e.data);
};

  

c.WebSocket事件 error
  定义:error 事件在响应意外故障的时候触发。与该事件对应的回调函数为onerror
  如果接收到一个error事件,可以预期很快就会触发close事件。close事件中的代码和原因有时候会告诉你错误的根源。
代码:

ws.onerror = function(e)
{
  cosole.log("WebSocket Error:",e);
  handleErrors(e);
};

d.WebSocket事件 close
定义:close事件在WebSocket连接关闭时触发 对应的回调函数为onclose 一旦关闭 服务终止
代码:

ws.onclose = function(e)
{
  console.log("connection closed",e);
};

3.Websocket有两种方法 send() 和 close()
  a.WebSocket方法: send()
    定义:使用send()方法可以从客户端向服务器发送消息在发送一条或者多条消息之后,可以保持连接打开,或者调用close() 方法终止连接 在调用onopen监视器之后 调用onclose监听器之前 调用send()方法
  代码:

ws.send("Hello Mark");

  注意:send()方法在连接打开的时候发送数据 如果连接不可用 或者 关闭 它会抛出一个无效连接状态的异常
  要避免试图在连接打开之前发送消息

  捕获js异常

var ws = new WebSocket("ws://120.77.245.130:2346");
try{
    ws.send(‘tom‘);
}catch(e){
    alert(e);
}
javascript Error 对象:
name: 错误名称
number: 错误号
description: 描述信息
message: 错误信息
fileName: 错误发生的文件
stack: 错误发生时的调用堆栈

  

    上面这个例子会抛出异常 因为连接尚未打开 要等onopen事件触发了 才能在新构造的WebSocket上发送第一条消息

var ws = new WebSocket("ws://120.77.245.130:2346");
ws.onopen = function()
{
  ws.send(‘tom‘);
}

  b.WebSocket方法:close()
    定义:使用close()方法 可以关闭WebSocket连接或者终止连接尝试 如果连接已经关闭,该方法就什么都不做。在调用close()之后,不能在已经关闭的WebSocket上发送任何数据
    参数:close(Param code,Param reason)
        code 数字型的状态代码 reason 一个文本字符串
    传递这两个信息,可以向服务器传递关闭的原因
  代码:

ws.close(1000,"closing normally");

4.Websocket的对象特性
  a. readyState 便于了解WebSocket 连接状态
  代码:

var ws = new WebSocket("ws://120.77.245.130:2346/");
alert(ws.readyState); //返回0 连接正在进行中 但还未建立 WebSocket.CONNECTING
ws.onopen = function(e){
  alert(ws.readyState);
  //返回1 连接已经建立。消息可以在客户端和服务器之间传递 WebSocket.CONNECTING
};
//下面不清楚
//返回2 连接正在进行关闭握手 WebSocket.CLOSING
ws.close();
alert(ws.readyState); //返回3 连接已经关闭,不能打开 WebSocket.CLOSED 

  b. bufferedAmount 数据在网上的传输速率 WebSocket对象可以告诉你缓存的大小
    bufferedAmount特性检查已经进入队列,但是尚未发送到服务器的字节数
  代码(使用bufferAmount特性每秒发送更新的例子,如过网络无法承受这一速率,它会做相应的调整):

var THRESHOLD = 10240;

var ws = new WebSocket("ws://120.77.245.130:2346/");

ws.onopen = function(){
setInterval(function(){
  if(ws.bufferedAmount < THRESHOLD)
  {
    ws.send(getApplicationState());
  }
},1000)
}

  

  对于限制应用向服务器发送数据的速率,从而避免网络饱和,bufferedAmount特性很有用。

  c. protocol
   在最初的握手之前为空 服务器没有选择客户端提供的哪个协议 该特性也为空值

5.判断浏览器是否支持WebSocket

if(window.WebSocket)
{
  console.log("this browser support WebSocket");
}else{
  console.log("this browser does not support WebSocket");
}

  

时间: 2024-07-31 12:54:58

HTML5 WebSocket 权威指南 学习一 (第二章 WebSocket API)的相关文章

《JS权威指南学习总结--第二章词法结构》

第二章词法结构 内容要点: 一.注释 1. //表示单行注释 2. /*这里是一段注释*/ 3.一般编辑器里加注释是:选中要加注释的语句,按 ctrl+/ 二.直接量 所谓直接量,就是程序中直接使用的数据量,比如: 数字.小数.字符串文本.布尔值.正则表达式直接量 三.标识符和保留字 标识符作用:标识符就是一个名字,在JS中,标识符用来对变量和函数进行命名,或者用做JS代码中某些循环语句中的跳转位置的标记. 标识符命名规则: 1.必须以字母.下划线(_)或美元符($)开始. 2.后续的字符可以是

学习《Javascript权威指南》的第二章笔记

1.Javascript区分大小写,但是HTML不区分大小写 2.JS会忽略标识之间的空格,多数情况下也会忽视换行符,所以要采用 整齐.一致的编码风格 3.//用作结尾的注释,/* 和 */可以当跨行的注释,但不能有嵌套的注 释 4.标识符必须以字母.下划线或美元符号开始(数字是不允许作为首字 符出现的),后续字符可以包括数字 为方便起见我们一般用ASCII字母和数字来表示 5.对于分号“:”如果一条语句是独占一行的就可以不用在后面加分号 注意:并不是在每一处换行时都要加上分号,只有在缺少了分号

《JS权威指南学习总结--第九章 类和模板》

内容要点: 一. 1.第六章详细介绍了JS对象,每个JS对象都是一个属性集合,相互之间没有任何联系.在JS中也可以定义对象的类,让每个对象都共享某些属性,这种"共享"的特性是非常有用的. 2.类的成员或实例都包含一些属性,用以存放或定义它们的状态,其中有些属性定义了它们的行为(通常称为方法).这些行为通常是由类定义的,而且为所有实例共享.例如,假设有一个名为Complex的类用来表示复数,同时还定义了一些复数运算. 一个Complex实例应当包含复数的实部和虚部(状态),同样Compl

css权威指南阅读笔记-第二章css选择器

css选择器有10+种.这里介绍几种常用的和他们的特点 1.元素选择器 如h1 h2 h3 a p 等一系列标签名 2 通配选择器 *,匹配所有html的元素 3 类选择器 class=‘a b'这种选择器在.a.b和.b.a是一样的,不区别先后顺序,另外类选择器区分大小写,class='A'在css中不能用.a匹配到,只能用.A匹配到 类选择器在页面中一般用于样式的复用 4 ID选择器 id选择器在页面中具有唯一性,并区分大小写,就是说box和BOX不是同一个ID 5 属性选择器 有4种模式

《Hadoop权威指南》笔记 第二章 Hadoop Streaming

什么是Hadoop Streaming ? ? Hadoop提供的一个编程工具,允许用户使用任何可执行文件或脚本作为mapper和Reducer ? ? 一个例子(shell简洁版本) ? ? $HADOOP_HOME/bin/hadoop jar $HADOOP_HOME/contrib/streaming/hadoop-*-streaming.jar -input myInputDirs -output myOutputDir -mapper cat -reducer wc ? ? 解析:

《Hadoop权威指南》笔记 第一章&第二章

? ? ? ? ? ? ? ? ? ? ? ? ? ? 使用MapReduce ? ? ? ? ? ? ? ? import java.io.IOException; // 是hadoop针对流处理优化的类型 import org.apache.hadoop.io.IntWritable; import org.apache.hadoop.io.LongWritable; import org.apache.hadoop.io.Text; // 会继承这个基类 import org.apache

《Hadoop权威指南》笔记 第一章&第二章 MapReduce初探

? ? ? ? ? ? ? ? ? ? ? ? ? ? 使用MapReduce ? ? ? ? ? ? ? ? import java.io.IOException; // 是hadoop针对流处理优化的类型 import org.apache.hadoop.io.IntWritable; import org.apache.hadoop.io.LongWritable; import org.apache.hadoop.io.Text; // 会继承这个基类 import org.apache

Git权威指南学习笔记(二)Git暂存区

如下图所示: 左侧为工作区,是我们的工作目录. 右侧为版本库,其中: index标记的是暂存区(stage),所处目录为.git/index,记录了文件的状态和变更信息. master标记的是master分支所代表的目录树.HEAD指向master分支. objects标记的是Git的对象库,所处目录为.git/objects,文件索引建立了文件和对象库中对象实体之间的映射关系. 通过该图我们可以清晰地看出add,commit等命令的转化关系.下面通过git diff和git status两条命

《JS权威指南学习总结--开始简介》

本书共分成了四大部分: 1.JS语言核心 2.客户端JS 3.JS核心参考 4.客户端JS核心参考 其中 <JS权威指南学习总结--1.1语法核心> 是:第一部分JS语言核心 各章节重点 简介 <JS权威指南学习总结--1.2客户端JS> 是:第二部分客户端JS 各章节重点 简介