WebSocket

mac2026-03-14  4

WebSocket

轮询:

客户端定时向服务器发送Ajax请求,服务器接到请求后马上返回响应信息并关闭连接。优点:后端程序编写比较容易。缺点:请求中有大半是无用,浪费带宽和服务器资源。实例:适于小型应用。

长轮询(coment):

客户端向服务器发送Ajax请求,服务器接到请求后hold住连接,直到有新消息才返回响应信息并关闭连接,客户端处理完响应信息后再向服务器发送新的请求。优点:在无消息的情况下不会频繁的请求,耗费资小。缺点:服务器hold连接会消耗资源,返回数据顺序无保证,难于管理维护。 Comet异步的ashx,实例:WebQQ、Hi网页版、Facebook IM。

长连接(SSE 全称为Server-Sent Events):

在页面里嵌入一个隐蔵iframe,将这个隐蔵iframe的src属性设为对一个长连接的请求或是采用xhr请求,服务器端就能源源不断地往客户端输入数据。优点:消息即时到达,不发无用请求;管理起来也相对便。缺点:服务器维护一个长连接会增加开销。实例:Gmail聊天

Websocket:

WebSocket是HTML5开始提供的一种浏览器与服务器间进行全双工通讯的网络技术。依靠这种技术可以实现客户端和服务器端的长连接,双向实时通信。特点:事件驱动;异步;使用ws或者wss(ws+TLS)协议的客户端socket能够实现真正意义上的推送功能缺点:少部分浏览器不支持,浏览器支持的程度与方式有区别。

WebSocket客户端

websocket允许通过JavaScript建立与远程服务器的连接,从而实现客户端与服务器间双向的通信。在websocket中有两个方法:       1、send() 向远程服务器发送数据     2、close() 关闭该websocket链接websocket同时还定义了几个监听函数         1、onopen 当网络连接建立时触发该事件     2、onerror 当网络发生错误时触发该事件     3、onclose 当websocket被关闭时触发该事件     4、onmessage 当websocket接收到服务器发来的消息的时触发的事件,也是通信中最重要的一个监听事件。msg.datawebsocket还定义了一个readyState属性,这个属性可以返回websocket所处的状态:     1、CONNECTING(0) websocket正尝试与服务器建立连接     2、OPEN(1) websocket与服务器已经建立连接     3、CLOSING(2) websocket正在关闭与服务器的连接     4、CLOSED(3) websocket已经关闭了与服务器的连接

websocket的url开头是ws,如果需要ssl加密可以使用wss,当我们调用websocket的构造方法构建一个websocket对象(new WebSocket(url))的之后,就可以进行即时通信了。

<!DOCTYPE html> <html> <head> <meta name="viewport" content="width=device-width" /> <title>WebSocket 客户端</title> </head> <body> <div> <input type="button" id="btnConnection" value="连接" /> <input type="button" id="btnClose" value="关闭" /> <input type="button" id="btnSend" value="发送" /> </div> <script src="js/jquery-1.11.1.min.js" type="text/javascript" charset="utf-8"></script> <script type="text/javascript"> var socket; if(typeof(WebSocket) == "undefined") { alert("您的浏览器不支持WebSocket"); return; } $("#btnConnection").click(function() { //实现化WebSocket对象,指定要连接的服务器地址与端口 socket = new WebSocket("ws://192.168.1.2:8888"); //打开事件 socket.onopen = function() { alert("Socket 已打开"); //socket.send("这是来自客户端的消息" + location.href + new Date()); }; //获得消息事件 socket.onmessage = function(msg) { alert(msg.data); }; //关闭事件 socket.onclose = function() { alert("Socket已关闭"); }; //发生了错误事件 socket.onerror = function() { alert("发生了错误"); } }); //发送消息 $("#btnSend").click(function() { socket.send("这是来自客户端的消息" + location.href + new Date()); }); //关闭 $("#btnClose").click(function() { socket.close(); }); </script> </body> </html>

WebSocket服务器端

JSR356定义了WebSocket的规范,Tomcat7中实现了该标准。JSR356 的 WebSocket 规范使用 javax.websocket.*的 API,可以将一个普通 Java 对象(POJO)使用 @ServerEndpoint 注释作为 WebSocket 服务器的端点。

@ServerEndpoint("/webSocketTest") public class EchoEndpoint { @OnOpen //在这个端点一个新的连接建立时被调用 public void onOpen(Session session) throws IOException { //以下代码省略... } @OnMessage //Java方法用于接收传入的WebSocket信息,这个信息可以是文本格式,也可以是二进制格式。 public String onMessage(String message) { //以下代码省略... } @OnError //错误时候执行 public void onError(Throwable t) { //以下代码省略... } /* * 在连接被终止时调用 * 参数closeReason可封装更多细节,如为什么一个WebSocket连接关闭。 * Session表明两个WebSocket端点对话连接的另一端,可以理解为类似HTTPSession的概念。 **/ @OnClose public void onClose(Session session, CloseReason reason) { //以下代码省略... } }
最新回复(0)