WebSocket實現(xiàn)Web聊天室功能
更新時間:2018年08月30日 14:37:22 作者:DOLFAMINGO
這篇文章主要為大家詳細(xì)介紹了WebSocket實現(xiàn)Web聊天室功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下
本文為大家分享了WebSocket實現(xiàn)Web聊天室的具體代碼,供大家參考,具體內(nèi)容如下
一.客戶端
JS代碼如下:
/* * 這部分js將websocket封裝起來 */ var websocket = null; //判斷當(dāng)前瀏覽器是否支持WebSocket if ('WebSocket' in window) { websocket = new WebSocket("ws://localhost:8080/GoodMan/ChatService"); } else { alert('當(dāng)前瀏覽器 Not support websocket') } //連接成功建立的回調(diào)方法 websocket.onopen = function () { alert("WebSocket連接成功"); } //連接發(fā)生錯誤的回調(diào)方法 websocket.onerror = function () { alert("WebSocket連接發(fā)生錯誤"); }; //發(fā)送消息 function sendMess(content) { var json ="{'username':'"+'${sessionScope.username }'+"', 'content':'"+content+"'}"; websocket.send(json); } //接收到消息的回調(diào)方法 websocket.onmessage = function (event) { var jsonString = event.data; //接收到的信息存放在event.data中 var data = JSON.parse(jsonString); //將json字符串轉(zhuǎn)換成js對象 // 然后輸出data } //連接關(guān)閉的回調(diào)方法 websocket.onclose = function () { alert("WebSocket連接關(guān)閉"); } //監(jiān)聽窗口關(guān)閉事件,當(dāng)窗口關(guān)閉時,主動去關(guān)閉websocket連接,防止連接還沒斷開就關(guān)閉窗口,server端會拋異常。 window.onbeforeunload = function () { closeWebSocket(); } //關(guān)閉WebSocket連接 function closeWebSocket() { websocket.close(); }
二.服務(wù)器
import java.io.IOException; import java.util.Date; import java.util.HashSet; import java.util.Set; import javax.websocket.*; import javax.websocket.server.ServerEndpoint; import com.google.gson.Gson; class Mess{ //封裝一條消息 private String username; private String content; private String date; public Mess(String username, String content, String date) { super(); this.username = username; this.content = content; this.date = date; } public String getUsername() { return username; } public void setUsername(String username) { this.username = username; } public String getContent() { return content; } public void setContent(String content) { this.content = content; } public String getDate() { return date; } public void setDate(String date) { this.date = date; } } @ServerEndpoint("/ChatService") public class ChatService { //每進(jìn)入一個用戶,就新建一個ChatService對象 private static int onlineCount = 0; //靜態(tài)變量, 用來記錄當(dāng)前在線連接數(shù) private static Set<ChatService> webSocketSet = new HashSet<>(); //靜態(tài)變量,用來存放在線用戶 private Session session; //用于存儲與該用戶的會話,要通過它來給客戶端發(fā)送數(shù)據(jù) /** * 連接建立成功調(diào)用的方法 * @param session 可選的參數(shù)。session為與某個客戶端的連接會話,需要通過它來給客戶端發(fā)送數(shù)據(jù) */ @OnOpen public void onOpen(Session session){ this.session = session; webSocketSet.add(this); //加入set中 addOnlineCount(); //在線數(shù)加1 System.out.println("有新連接加入!當(dāng)前在線人數(shù)為" + getOnlineCount()); } /** * 連接關(guān)閉調(diào)用的方法 */ @OnClose public void onClose(){ webSocketSet.remove(this); //從set中刪除 subOnlineCount(); //在線數(shù)減1 System.out.println("有一連接關(guān)閉!當(dāng)前在線人數(shù)為" + getOnlineCount()); } /** * 收到客戶端消息后調(diào)用的方法 * @param message 客戶端發(fā)送過來的消息 * @param session 可選的參數(shù) */ @OnMessage public void onMessage(String data, Session session) { Mess mess = new Gson().fromJson(data, Mess.class); System.out.printf("來%s的消息:%s\n", mess.getUsername(), mess.getContent()); //群發(fā)消息 for(ChatService item: webSocketSet){ try { item.sendMessage(mess); } catch (IOException e) { e.printStackTrace(); continue; } } } /** * 發(fā)生錯誤時調(diào)用 * @param session * @param error */ @OnError public void onError(Session session, Throwable error){ System.out.println("發(fā)生錯誤"); error.printStackTrace(); } //以下為輔助函數(shù) public void sendMessage(Mess mess) throws IOException{ String datatime = new java.text.SimpleDateFormat("yyyy-MM-dd hh:mm:ss").format(new Date()); mess.setDate(datatime); String jsonInfo = new Gson().toJson(mess); //將消息對象轉(zhuǎn)換成json字符串 this.session.getAsyncRemote().sendText(jsonInfo); //通過session異步地將信息發(fā)送到客戶端上 } public static synchronized int getOnlineCount() { return onlineCount; } public static synchronized void addOnlineCount() { ChatService.onlineCount++; } public static synchronized void subOnlineCount() { ChatService.onlineCount--; } }
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
您可能感興趣的文章:
- 使用WebSocket實現(xiàn)即時通訊(一個群聊的聊天室)
- Android使用Websocket實現(xiàn)聊天室
- swoole和websocket簡單聊天室開發(fā)
- express框架實現(xiàn)基于Websocket建立的簡易聊天室
- Node.js websocket使用socket.io庫實現(xiàn)實時聊天室
- 基于Tomcat7、Java、WebSocket的服務(wù)器推送聊天室實例
- php基于websocket搭建簡易聊天室實踐
- 用java WebSocket做一個聊天室
- 基于Swoole實現(xiàn)PHP與websocket聊天室
- golang基于websocket實現(xiàn)的簡易聊天室程序
- 使用Java和WebSocket實現(xiàn)網(wǎng)頁聊天室實例代碼
- JavaEE7+Websockets+GlassFish4打造聊天室
- php+html5基于websocket實現(xiàn)聊天室的方法
相關(guān)文章
SpringBoot統(tǒng)一響應(yīng)格式及統(tǒng)一異常處理
在我們開發(fā)SpringBoot后端服務(wù)時,一般需要給前端統(tǒng)一響應(yīng)格式,本文主要介紹了SpringBoot統(tǒng)一響應(yīng)格式及統(tǒng)一異常處理2023-05-05Java配置JDK開發(fā)環(huán)境及環(huán)境變量
這篇文章主要為大家詳細(xì)介紹了Java配置JDK開發(fā)環(huán)境及環(huán)境變量,文中安裝步驟介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-09-09java構(gòu)建OAuth2授權(quán)服務(wù)器
本文主要介紹了java構(gòu)建OAuth2授權(quán)服務(wù)器,文中通過示例代碼介紹的非常詳細(xì),需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-07-07利用 filter 機(jī)制給靜態(tài)資源 url 加上時間戳,來防止js和css文件的緩存問題
這篇文章主要介紹了利用 filter 機(jī)制給靜態(tài)資源 url 加上時間戳,來防止js和css文件的緩存問題的相關(guān)資料,需要的朋友可以參考下2016-05-05使用IDEA和Gradle構(gòu)建Vertx項目(圖文步驟)
這篇文章主要介紹了使用IDEA和Gradle構(gòu)建Vertx項目(圖文步驟),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-09-09