内容简介:WebSocket protocol 是HTML5 一种新的协议。它是实现了浏览器与服务器全双工通信。HTML5定义了WebSocket 协议,能更好的节省服务器资源和带宽并达到实时通讯。
WebSocket protocol 是HTML5 一种新的协议。
它是实现了浏览器与服务器全双工通信。
HTML5定义了WebSocket 协议,能更好的节省服务器资源和带宽并达到实时通讯。
问什么会使用WebSocket
HTML页面在刚刚开始出现的时候是静态的,不能够进行交互。
直到后来有了JavaScript ,在一定程度上解决了这个问题,但是JavaScript 刚出现的时候并不能和服务器进行交互。
直到Ajax 的出现,Ajax 有效的解决了页面和服务器段进行交互的问题。不过Ajax 有一个问题,就是所有的请求都必须由客户端发起,服务端进行响应,如果服务器端有最新的消息,难以即时的发送到客户端上去。
在WebSocket 技术出现之前,为了让客户端能够即时的活服务端的数据,采用了如下三种方案。
轮询
这是最简单的一种解决方案,也就是客户端在固定的时间间隔下(一般是1秒)不停的向服务器端发送请求,查看服务器端是否有最新的数据,服务器端如果有最新的数据,则返回给客户端。如果服务端没有,则返回一个空的json 或者xml 文档。
这种实现方式看起来很简单,但是弊端也很明显,就是会有大量的无效请求,服务端的资源被大大的浪费了。
长连接
长连接和轮询有些许类似,不同的是服务端不是每次都会响应客户端的请求,只有在服务器有最新数据的时候才会响应客户端的请求。
这种方式很明显会节省网络的资源和服务器资源,但是也会存在一些问题:
- 如果浏览器在服务器响应之前有新数据要发送就只能创建一个新的并发请求,或者先尝试断掉当前请求然后再创建新的请求。
- TCP 和HTTP 规范中都有可能出现 连接超时 的情况,所以所谓的长连接并不能一直持续,服务端和客户端的连接需要定期的连接和关闭再连接。
Applet和Flash
这两个技术除了可以让我们的HTML 页面更加绚丽之外,还可以解决消息推送的问题。开发者可以用一个像素嗲大小的普通透明的Apple 或者Flash ,然后将之内嵌在页面中,然后这个Applet 或者Flash 中的代码创建出一个Socket 连接,这种连接方式消除了HTTP协议中的各种限制。
当服务器有消息发送到客户端的时候,开发者可以在Applet 或者Flash中调用JavaScript 函数,然后更新页面。
当浏览器有数据要发送给服务器的时候也一样,通过Applet 或者Flash 来传递。
这种方式真正的实现了全双工通信,但是也存在问题:
- 浏览器必须能够运行 Java 或者Flash
- 无论是Applet 还是Flash 都存在安全问题
- 随着HTML5 标准在浏览器中广泛支持,Flash下架已经被提上日程
WebSocket
引入
通过在客户端在请求头HTTPConnection : Upgrade 来希望升级协议。
通过Upgrade 头中指定一个或者多个协议的列表(这些协议必须兼容HTTP/1.1)。
在服务器收到请求之后,如果接受升级请求,将会返回一个101的状态码,表示转换请求协议同时相应Upgrade头中时通 ‘单个值’,这个单个值就是请求协议列表中服务器支持的第一个协议。
通过各种各样的协议从而创建不同的TCP通信。浏览器并不会让开发者随意去这么做,而是要制定某些协议,就这样webSocket应运而生!
使用HTTP/1.1升级的WebSocket
一个WebSocket请求首先使用正常的HTTP请求以特定的模式访问一个URL,这个URL 有两种模式,分别是ws 和 wss 对应HTTP协议中的http 和https 。
请求头中除了Connection : Upgrade 之外还有一个 Upgrade : websocket,它们两个将共同告诉服务器将连接升级为WebScket 这样的全双工协议。
如此,在握手完成之后,文本消息或者其他二进制消息就可以同时在两个方向上进行发送,而不需要关闭和重建连接,此时的客户端和服务端关系其实是对等的,它们都可以相互想对方主动发消息。
这里需要注意:
ws 和wss 模式并不能算作HTTP协议的一部分,因为HTTP请求和请求头并不包含URL模式,HTTP请求只能在请求的第一行中包含相对与服务器的URL,在Host头中包含域名,而WebSocket中特有的ws 和wss 模式主要用于通知浏览器和API 是希望使用SSL/TSL(wss) ,还是希望使用不加密的方法(ws)进行连接。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:- 这些 iOS 冷知识,你知道吗?
- 关于编码你必须知道的知识和技巧
- 关于 Babel 你必须知道的基础知识
- 关于 Babel 你必须知道的基础知识
- 你可能不知道的 ZooKeeper 知识点
- 你应该知道的缓动知识点
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
JavaScript设计模式
Ross Harmes、Dustin Diaz / 谢廷晟 / 人民邮电出版社 / 2008 / 45.00元
本书共有两部分。第一部分给出了实现具体设计模式所需要的面向对象特性的基础知识,主要包括接口、封装和信息隐藏、继承、单体模式等内容。第二部分则专注于各种具体的设计模式及其在JavaScript语言中的应用,主要介绍了工厂模式、桥接模式、组合模式、门面模式等几种常见的模式。为了让每一章中的示例都尽可能地贴近实际应用,书中同时列举了一些JavaScript 程序员最常见的任务,然后运用设计模式使其解决方......一起来看看 《JavaScript设计模式》 这本书的介绍吧!