今天帶來的是webSocket技術。若有不足,敬請指正。。百度百科中這樣解釋:javascript
如今,不少網站爲了實現推送技術,所用的技術都是輪詢。輪詢是在特定的的時間間隔(如每1秒),由瀏覽器對服務器發出HTTP請求,而後由服務器返回最新的數據給客戶端的瀏覽器。這種傳統的模式帶來很明顯的缺點,即瀏覽器須要不斷的向服務器發出請求,然而HTTP請求可能包含較長的頭部,其中真正有效的數據可能只是很小的一部分,顯然這樣會浪費不少的帶寬等資源。html
而比較新的技術去作輪詢的效果是Comet。這種技術雖然能夠雙向通訊,但依然須要反覆發出請求。並且在Comet中,廣泛採用的長連接,也會消耗服務器資源。前端
在這種狀況下,HTML5定義了WebSocket協議,能更好的節省服務器資源和帶寬,而且可以更實時地進行通信。java
項目啓動時會自動啓動,相似與ContextListener,是WebSocket的核心配置。 其有兩個方法:web
注:EndPoint就指的是一個webSocket的一個服務端程序。編程
項目結構 |
---|
package com.rrs.config; import java.util.Set; import javax.websocket.Endpoint; import javax.websocket.server.ServerApplicationConfig; import javax.websocket.server.ServerEndpointConfig; /** * @author lzx * */ public class DemoConfig implements ServerApplicationConfig { // 註解式方式編程 @Override public Set<Class<?>> getAnnotatedEndpointClasses(Set<Class<?>> scan) { System.out.println("webSocket:" + scan.size()); // 服務端掃描到服務返回,能夠起到過濾做用 return scan; } // 接口式方式編程 @Override public Set<ServerEndpointConfig> getEndpointConfigs(Set<Class<? extends Endpoint>> endpointClasses) { // TODO Auto-generated method stub return null; } }
package com.rrs.socket; import java.io.IOException; import javax.websocket.OnClose; import javax.websocket.OnMessage; import javax.websocket.OnOpen; import javax.websocket.Session; import javax.websocket.server.ServerEndpoint; //多例模式 /** * @author lzx * */ @ServerEndpoint("/echo") public class EchoSocket { @OnOpen // 只要訪問此路徑此方法就會執行 public void open(Session session) { // 一個session 表明一個會話(管道) System.out.println("sessionId:" + session.getId() + "開啓..."); } @OnMessage public void getMessage(Session session, String msg) { System.out.println("來自客戶端的消息:" + msg); // 服務器發送消息 try { session.getBasicRemote().sendText("服務器發送消息:Hello客戶端 "); } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); } } // 會話關閉的時候調用 @OnClose public void close(Session session) { System.out.println("sessionId:" + session.getId() + "關閉..."); } }
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>webScoket</title> </head> <body> <button onclick=subOpen();>send</button> <br> <input type="text" id="message" /> <button onclick=subSend();>send2</button> <div id="sp"></div> <script type="text/javascript"> var ws;//一個ws對象就是一個通訊管道 var target = "ws://localhost:8080/websocketproject/echo"; function subOpen(){ if ('WebSocket' in window) { ws = new WebSocket(target); } else if ('MozWebSocket' in window) { ws = new MozWebSocket(target); } else { alert('WebSocket is not supported by this browser.'); return; } } function subSend(){ if (ws != null) { var message = document.getElementById('message').value; ws.send(message); document.getElementById('message').value="" // 經過事件 ws.onmessage = function(event){ var sp = document.getElementById("sp"); sp.innerHTML+=event.data; } } else { alert('WebSocket connection not established, please connect.'); } } </script> </body> </html>
console |
---|
瀏覽器,服務器 |
---|
版權說明:歡迎以任何方式進行轉載,但請在轉載後註明出處!後端