WebSocket實(shí)現(xiàn)Web聊天室功能
本文為大家分享了WebSocket實(shí)現(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ā)生錯(cuò)誤的回調(diào)方法
websocket.onerror = function () {
alert("WebSocket連接發(fā)生錯(cuò)誤");
};
//發(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對(duì)象
// 然后輸出data
}
//連接關(guān)閉的回調(diào)方法
websocket.onclose = function () {
alert("WebSocket連接關(guān)閉");
}
//監(jiān)聽窗口關(guān)閉事件,當(dāng)窗口關(guān)閉時(shí),主動(dòng)去關(guān)閉websocket連接,防止連接還沒斷開就關(guān)閉窗口,server端會(huì)拋異常。
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)入一個(gè)用戶,就新建一個(gè)ChatService對(duì)象
private static int onlineCount = 0; //靜態(tài)變量, 用來記錄當(dāng)前在線連接數(shù)
private static Set<ChatService> webSocketSet = new HashSet<>(); //靜態(tài)變量,用來存放在線用戶
private Session session; //用于存儲(chǔ)與該用戶的會(huì)話,要通過它來給客戶端發(fā)送數(shù)據(jù)
/**
* 連接建立成功調(diào)用的方法
* @param session 可選的參數(shù)。session為與某個(gè)客戶端的連接會(huì)話,需要通過它來給客戶端發(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ā)生錯(cuò)誤時(shí)調(diào)用
* @param session
* @param error
*/
@OnError
public void onError(Session session, Throwable error){
System.out.println("發(fā)生錯(cuò)誤");
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); //將消息對(duì)象轉(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)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- 使用WebSocket實(shí)現(xiàn)即時(shí)通訊(一個(gè)群聊的聊天室)
- Android使用Websocket實(shí)現(xiàn)聊天室
- swoole和websocket簡單聊天室開發(fā)
- express框架實(shí)現(xiàn)基于Websocket建立的簡易聊天室
- Node.js websocket使用socket.io庫實(shí)現(xiàn)實(shí)時(shí)聊天室
- 基于Tomcat7、Java、WebSocket的服務(wù)器推送聊天室實(shí)例
- php基于websocket搭建簡易聊天室實(shí)踐
- 用java WebSocket做一個(gè)聊天室
- 基于Swoole實(shí)現(xiàn)PHP與websocket聊天室
- golang基于websocket實(shí)現(xiàn)的簡易聊天室程序
- 使用Java和WebSocket實(shí)現(xiàn)網(wǎng)頁聊天室實(shí)例代碼
- JavaEE7+Websockets+GlassFish4打造聊天室
- php+html5基于websocket實(shí)現(xiàn)聊天室的方法
相關(guān)文章
Java別說取余(%)運(yùn)算簡單你真的會(huì)嗎
這篇文章主要介紹了Java別說取余(%)運(yùn)算簡單你真的會(huì)嗎,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-07-07
java并發(fā)中DelayQueue延遲隊(duì)列原理剖析
DelayQueue隊(duì)列是一個(gè)延遲隊(duì)列,本文將結(jié)合實(shí)例代碼,詳細(xì)的介紹DelayQueue延遲隊(duì)列的源碼分析,感興趣的小伙伴們可以參考一下2021-06-06
SpringBoot統(tǒng)一響應(yīng)格式及統(tǒng)一異常處理
在我們開發(fā)SpringBoot后端服務(wù)時(shí),一般需要給前端統(tǒng)一響應(yīng)格式,本文主要介紹了SpringBoot統(tǒng)一響應(yīng)格式及統(tǒng)一異常處理2023-05-05
Java配置JDK開發(fā)環(huán)境及環(huán)境變量
這篇文章主要為大家詳細(xì)介紹了Java配置JDK開發(fā)環(huán)境及環(huán)境變量,文中安裝步驟介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-09-09
java構(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 加上時(shí)間戳,來防止js和css文件的緩存問題
這篇文章主要介紹了利用 filter 機(jī)制給靜態(tài)資源 url 加上時(shí)間戳,來防止js和css文件的緩存問題的相關(guān)資料,需要的朋友可以參考下2016-05-05
使用IDEA和Gradle構(gòu)建Vertx項(xiàng)目(圖文步驟)
這篇文章主要介紹了使用IDEA和Gradle構(gòu)建Vertx項(xiàng)目(圖文步驟),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-09-09
AntDesign多環(huán)境配置啟動(dòng)過程詳解
這篇文章主要為大家介紹了AntDesign多環(huán)境配置啟動(dòng)過程詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-11-11

