亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定

基于WebSocket的聊天室(解決輪詢和長連接的缺點)

標簽:
Html5

websocket是HTML5重要的功能之一,websokcet的目的是实现通信功能。

先比较正常的HTTP请求和websocket通信,

正常情况:页面所在web服务器发送一个HTTP请求。web服务器识别请求,然后返回响应。轮询便是定时发送HTTP请求,有时候并不能达到实时通讯。

长连接原理跟轮询差不多,都是采用轮询的方式,不过采取的是阻塞模型,客户端发起连接后,如果没消息,就一直不返回Response给客户端。直到有消息才返回,返回完之后,客户端再次建立连接,周而复始。这样加大了服务器的压力。

而websocket提供了双向的、按序到达的数据流,一但连接成功,就可以在全双工模式下在客户端和服务器之间来回传送websocket消息。

wesocket的优点如下:

1、服务器与客户端之间交换的标头信息很小。

2、客户端与服务器都可以主动传送数据给对方。

3、不用频率创建TCP请求及销毁请求,减少网络宽带资源的占用,同时也节省服务器资源。

既然这么多优点我也就开始查看websocket api 然后尝试了做一个简单的聊天室。

websocket需要先实例化 new WebSocket(url,protocol)

                url 为 ws:// 或 wss:// 前缀加上服务器地址 例如:ws://localhost:3000

                protocol(可选)为能够使用的协议,可以是字符串也可以是数组

websocket遵循异步编程,不需要主动轮询。websocket对象有4个事件

onopen:当建立连接时触发

onmessage:当有消息接收时触发

onclose:当连接关闭时触发

:当发生错误时触发

1个方法

send:用来发送消息

最开始打算用php做,网上查看了一些,但是一直失败所以选择了node,还请各位大神能给个php的源码

这是我基于Node.js+websocket做的聊天室:github.com/wenlei0617/node-websocket

浏览器的兼容性现在也是很好的,所以可以放心使用

webp



作者:_Gary
链接:https://www.jianshu.com/p/04d1e1df2ed3


點擊查看更多內容
TA 點贊

若覺得本文不錯,就分享一下吧!

評論

作者其他優質文章

正在加載中
  • 推薦
  • 評論
  • 收藏
  • 共同學習,寫下你的評論
感謝您的支持,我會繼續努力的~
掃碼打賞,你說多少就多少
贊賞金額會直接到老師賬戶
支付方式
打開微信掃一掃,即可進行掃碼打賞哦
今天注冊有機會得

100積分直接送

付費專欄免費學

大額優惠券免費領

立即參與 放棄機會
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號

舉報

0/150
提交
取消