摘要:国际惯例,先上维基百科的解释。维基百科上面是维基百科对的解释,别问我如何解释上面这段话,因为我也没看懂,那么下面我用人话解释一下吧仅仅是我的理解是一个协议,可以简单看成是协议的一个补充协议,借助协议的基础完成服务器主动与客户端实时传输数据。
现在,很多网站为了实现推送技术,所用的技术都是轮询。轮询是在特定的的时间间隔(如每1秒),由浏览器对服务器发出HTTP request,然后由服务器返回最新的数据给客户端的浏览器。这种传统的模式带来很明显的缺点,即浏览器需要不断的向服务器发出请求,然而HTTP request的header是非常长的,里面包含的数据可能只是一个很小的值,这样会占用很多的带宽和服务器资源。
Ajax轮询——“定时的通过Ajax查询服务端"
而比较新的技术去做轮询的效果是Comet,使用了AJAX。但这种技术虽然可达到双向通信,但依然需要发出请求,而且在Comet中,普遍采用了长链接,这也会大量消耗服务器带宽和资源。
Comet——随着AJAX技术兴起而产生的新技术
用大白话揭开Ajax长轮询(long polling)的神秘面纱
面对这种状况,HTML5定义了WebSocket协议,能更好的节省服务器资源和带宽并达到实时通讯。
国际惯例,先上维基百科的解释。
"WebSocket是HTML5开始提供的一种在单个 TCP 连接上进行全双工通讯的协议。"
——维基百科
上面是维基百科对WebSocket的解释,别问我如何解释上面这段话,因为我也没看懂,那么下面我用人话解释一下吧(仅仅是我的理解):
WebSocket是一个协议,可以简单看成是HTTP协议的一个补充协议,WebSocket借助HTTP协议的基础完成服务器主动与客户端实时传输数据。
这是WebSocket和HTTP之间的关系,有交集,但是并不是全部。
WebSocket只是HTML5其中的一个API(HTML5推出了很多新的API,赞),这个API可以通过WebSocket协议实现WebSocket技术。
在WebSocket API中,浏览器和服务器只需要做一个握手的动作,然后,浏览器和服务器之间就形成了一条快速通道。两者之间就直接可以数据互相传送。
关键点在于如何"握手",只要我们完成了握手的这个工作,那么WebScoket技术就算是能够使用了。
前面说了WebSocket与HTTP有交集的,或者可以说WebSocket借助了HTTP的基础就是体现在这里了,可以看到图中的红点,分别是WebSocket的请求头和响应头,一来一回,握手也就完成了,实时连接也就建立起来了!
下面讲解一下几个重要的头参数:
Request: Upgrade:WebSocket; //指定WebSocket协议 Sec-WebSocket-Version: 13 //指定Websocket Draft协议版本 Sec-WebSocket-Key:Cv8RLRCr07Ujlqexqq9Nrw== //验证key值,由浏览器随机生成,可以理解为一个校验码 Reponse: Connection:Upgrade ; Upgrade:webSocket;//没错我就是webSocket Sec-WebSocket-Accept:rC+mM80welcslAqBHpav4MSDzAU= ;//这是返回头校验码,和请求头的Key配对 Sec-WebSocket-Version: 13 //指定Websocket Draft协议版本
以上就是一次完成的WebSocket握手,握手完之后就可以进行实时通信了。
先上个代码看看:
本文所用服务端语言为PHP,其他语言可以对照着看,大的原理都一样:
WebSocket Demo下载链接(代码实在太长,直接下载吧)
使用方法
Windows下要用cmd启动server.php文件,Linux同理 然后用浏览器访问index.html Demo是上网找的,不能当做实际用途,简单看看运行流程就好
代码需要改的就是index.html的url和server.php的ip。
我讲解几个重要的模块
server.php:
"127.0.0.1", "port"=>"8000", "event"=>"WSevent",//回调函数的函数名 "log"=>true, ); $websocket = new websocket($config); $websocket->run();
server.php:通过cmd运行server.php,引用并实例化websocket.class.php类库,并执行run方法,使其充当一个"服务器",持续挂着这个连接,当客户端有消息就做出对应动作。
Index.html:
websocket_TEST
Index.html:HTML5提供了WebSocket API,所以,客户端实例化此API,参数为IP:端口,连接上服务端的WebSocket连接。
function roboot()
function roboot($sign,$t){ global $websocket; switch ($t) { case "hello": $show="hello,GIt @ OSC"; break; case "name": $show="Robot"; break; case "time": $show="当前时间:".date("Y-m-d H:i:s"); break; case "再见": $show="( ^_^ )/~~拜拜"; $websocket->write($sign,"Robot:".$show); $websocket->close($sign); return; break; case "天王盖地虎": $array = array("小鸡炖蘑菇","宝塔震河妖","粒粒皆辛苦"); $show = $array[rand(0,2)]; break; default: $show="( ⊙o⊙?)不懂,你可以尝试说:hello,name,time,再见,天王盖地虎."; } $websocket->write($sign,"Robot:".$show); }
function roboot():指定了客户端的操作和服务端回复的信息,客户端发送" 天王盖地虎",服务端返回信息" 小鸡炖蘑菇"/" 宝塔震河妖"/" 粒粒皆辛苦"。
文章最后来个小科普:
关于Socket 与 WebScoket
Socket 其实并不是一个协议。它工作在 OSI 模型会话层(第5层),是为了方便大家直接使用更底层协议(一般是 TCP 或 UDP )而存在的一个抽象层。
最早的一套 Socket API 是 Berkeley sockets ,采用 C 语言实现。它是 Socket 的事实标准,POSIX sockets 是基于它构建的,多种编程语言都遵循这套 API,在 JAVA、Python 中都能看到这套 API 的影子。
下面摘录一段更容易理解的文字(来自 http和socket之长连接和短连接区别):
Socket是应用层与TCP/IP协议族通信的中间软件抽象层,它是一组接口。在设计模式中,Socket其实就是一个门面模式,它把复杂的TCP/IP协议族隐藏在Socket接口后面,对用户来说,一组简单的接口就是全部,让Socket去组织数据,以符合指定的协议。
主机 A 的应用程序要能和主机 B 的应用程序通信,必须通过 Socket 建立连接,而建立 Socket 连接必须需要底层 TCP/IP 协议来建立 TCP 连接。建立 TCP 连接需要底层 IP 协议来寻址网络中的主机。我们知道网络层使用的 IP 协议可以帮助我们根据 IP 地址来找到目标主机,但是一台主机上可能运行着多个应用程序,如何才能与指定的应用程序通信就要通过 TCP 或 UPD 的地址也就是端口号来指定。这样就可以通过一个 Socket 实例唯一代表一个主机上的一个应用程序的通信链路了。
而 WebSocket 则不同,它是一个完整的 应用层协议,包含一套标准的 API 。
所以,从使用上来说,WebSocket 更易用,而 Socket 更灵活。
再简单来说, Socket是一个应用程序接口,是抽象的,WebSocket和HTTP是具体实现,
参考文章:
https://www.zhihu.com/question/20215561 《 知乎回答:什么是WebSocket?》
https://zh.wikipedia.org/wiki/WebSocket 《维基百科:WebSocket》
http://zengrong.net/post/2199.htm 《zrong"s blog》
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/30351.html
摘要:本文对过去和现在流行的实时推送技术进行了比较与总结。以上我们介绍了三种实时推送技术,然而各自的缺点很明显,使用起来并不理想,接下来我们着重介绍另一种技术它是比较理想的双向通信技术。 前言 随着 Web 的发展,用户对于 Web 的实时推送要求也越来越高 ,比如,工业运行监控、Web 在线通讯、即时报价系统、在线游戏等,都需要将后台发生的变化主动地、实时地传送到浏览器端,而不需要用户手动...
摘要:长轮循长轮循是对定时轮询的改进和提高,目地是为了降低无效的网络传输。是规范的一部分,它是一种流技术,它的规范由两部分组成,第一个部分是服务器端与浏览器端之间的通讯协议,第二部分则是在浏览器端提供使用的对象。下一篇之客户端与服务器端的交互二 1. 长链接技术介绍 说到websocket,必须讲到在它之前的各种长链接技术,比如轮循,长轮循,sse等。长链接顾名思义,就是让客户端浏览器与服务...
摘要:当用户注销或退出时,释放连接,清空对象中的登录状态。聊天管理模块系统的核心模块,这部分主要使用框架实现,功能包括信息文件的单条和多条发送,也支持表情发送。描述读取完连接的消息后,对消息进行处理。 0.前言 最近一段时间在学习Netty网络框架,又趁着计算机网络的课程设计,决定以Netty为核心,以WebSocket为应用层通信协议做一个互联网聊天系统,整体而言就像微信网页版一样,但考虑...
摘要:并且指定收到消息,以及端口的监听方法。四代码示例多房间实时聊天室配置版本须在里配置定义,并设置。使同一个的请求能够落在同一个机器同一个进程中。通过主进程统一管理维护子进程,每个进程监听一个端口。 showImg(http://7tszky.com1.z0.glb.clouddn.com/FkhApdRySR927nkdDZuUPBQbJtXG); 一、相关技术介绍: 消息实时推送,指的...
阅读 3262·2021-09-22 15:58
阅读 1725·2019-08-30 14:17
阅读 1729·2019-08-28 18:05
阅读 1515·2019-08-26 13:33
阅读 694·2019-08-26 12:20
阅读 616·2019-08-26 12:18
阅读 3198·2019-08-26 11:59
阅读 1413·2019-08-26 10:36