HTML5 WebSocket的使用及例子

4 篇文章 0 订阅

WebSocket protocol 是HTML5一种新的协议(protocol)。它是实现了浏览器与服务器全双工通信(full-duplex)。
现在,很多网站为了实现即时通讯(real-time),所用的技术都是轮询(polling)。轮询是在特定的的时间间隔(time interval)(如每1秒),由浏览器对服务器发出HTTP request,然后由服务器返回最新的数据给客服端的浏览器。这种传统的HTTP request d的模式带来很明显的缺点 – 浏览器需要不断的向服务器发出请求(request),然而HTTP request 的header是非常长的,里面包含的数据可能只是一个很小的值,这样会占用很多的带宽。
而最比较新的技术去做轮询的效果是Comet – 用了AJAX。但这种技术虽然可达到全双工通信,但依然需要发出请求(reuqest)。
在 WebSocket API,浏览器和服务器只需要要做一个握手的动作,然后,浏览器和服务器之间就形成了一条快速通道。两者之间就直接可以数据互相传送。在此WebSocket 协议中,为我们实现即使服务带来了两大好处:

  1. Header
    互相沟通的Header是很小的-大概只有 2 Bytes
  2. Server Push
    服务器可以主动传送数据给客户端

下面实现一个简单PUSH例子如下:
服务端代码:

  public class InitServlet extends HttpServlet {


/**
* 
*/
private static final long serialVersionUID = 1L;
private static List<MessageInbound> socketList;


public void init(ServletConfig config) throws ServletException {
InitServlet.socketList = new ArrayList<MessageInbound>();
super.init(config);
System.out.println("Server start============");
}


public static List<MessageInbound> getSocketList() {
return InitServlet.socketList;
}


}

  

  public class TestWebSocketServlet extends WebSocketServlet{


private static final Logger log = Logger.getLogger(TestWebSocketServlet.class);
/**
* 
*/
private static final long serialVersionUID = 1L;
//存储链接的容器
private  static  List<WebSocketMessageInbound> connsList = new ArrayList<WebSocketMessageInbound>();
@Override
protected StreamInbound createWebSocketInbound(String subProtocol,HttpServletRequest request) {
// TODO Auto-generated method stub
return new WebSocketMessageInbound();
}
public class WebSocketMessageInbound extends MessageInbound{


@Override  
   protected void onClose(int status) {  
//        InitServlet.getSocketList().remove(this);  
super.onClose(status);  
log.debug("onClose");
InitServlet.getSocketList().remove(this);
   }  

   @Override  
   protected void onOpen(WsOutbound outbound) {  
    log.debug("onOpen");
       super.onOpen(outbound);  
       InitServlet.getSocketList().add(this);
   }  
@Override
protected void onBinaryMessage(ByteBuffer message) throws IOException {
// TODO Auto-generated method stub
log.debug("onBinaryMessage");
}


@Override
protected void onTextMessage(CharBuffer message) throws IOException {
// TODO Auto-generated method stub
log.debug("onTextMessage="+message);
// this.getWsOutbound().writeTextMessage(CharBuffer.wrap("===="));
// this.getWsOutbound().writeTextMessage(message);
//发送给所有链接的
for (MessageInbound messageInbound : InitServlet.getSocketList()) {  
           CharBuffer buffer = CharBuffer.wrap(message);  
           WsOutbound outbound = messageInbound.getWsOutbound();  
           outbound.writeTextMessage(buffer);  
           outbound.flush();  
       }  
}

}
}

web.xml配置

<servlet>
<servlet-name>initServlet</servlet-name>
<servlet-class>com.demo.websocket.InitServlet</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet>
<servlet-name>websocket</servlet-name>
<servlet-class>com.demo.websocket.TestWebSocketServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>websocket</servlet-name>
<url-pattern>/websocket</url-pattern>
</servlet-mapping>

前台代码:

  <html> 
     <head> 
         <title>WebSoket Demo</title> 
         <script type="text/javascript"> 
             //验证浏览器是否支持WebSocket协议
             if (!window.WebSocket) { 
                 alert("WebSocket not supported by this browser!"); 
             } 
              var ws;
             function display() { 
                 //var valueLabel = document.getElementById("valueLabel"); 
                 //valueLabel.innerHTML = ""; 
                 ws=new WebSocket("ws://localhost:8082/SpringMVC/websocket"); 
                 //监听消息
                 ws.onmessage = function(event) { 
                     //valueLabel.innerHTML+ = event.data; 
                     log(event.data);
                 }; 
                 // 打开WebSocket 
                 ws.onclose = function(event) { 
                   //WebSocket Status:: Socket Closed
                 }; 
                 // 打开WebSocket
                 ws.onopen = function(event) { 
                    //WebSocket Status:: Socket Open
                      发送一个初始化消息
                     ws.send("Hello, Server!"); 
                 }; 
                 ws.onerror =function(event){
                     //WebSocket Status:: Error was reported
                 };
             } 
             var log = function(s) {  
   if (document.readyState !== "complete") {  
       log.buffer.push(s);  
   } else {  
       document.getElementById("contentId").innerHTML += (s + "\n");  
   }  
}  
             function sendMsg(){
                 var msg=document.getElementById("messageId");
                 //alert(msg.value);
                 ws.send(msg.value); 
             }
         </script> 
     </head> 
     <body onload="display();"> 
         <div id="valueLabel"></div> 
         <textarea rows="20" cols="30" id="contentId"></textarea>
         <br/>
         <input name="message" id="messageId"/>
         <button id="sendButton" onClick="javascript:sendMsg()" >Send</button>
     </body> 
</html> 

备注:必须把TOMCAT7 lib目录下的两个jar文件catalina.jar、tomcat-coyote.jar添加到项目的lib。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

日霄科技

感谢各位大佬,您鼓励是我的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值