本文為大家分享了WebSocket實現Web聊天室的具體代碼,供大家參考,具體內容如下
專注于為中小企業提供成都網站設計、做網站服務,電腦端+手機端+微信端的三站合一,更高效的管理,為中小企業虹口免費做網站提供優質的服務。我們立足成都,凝聚了一批互聯網行業人才,有力地推動了成百上千企業的穩健成長,幫助中小企業通過網站建設實現規模擴充和轉變。
一.客戶端

JS代碼如下:
/*
* 這部分js將websocket封裝起來
*/
var websocket = null;
//判斷當前瀏覽器是否支持WebSocket
if ('WebSocket' in window) {
websocket = new WebSocket("ws://localhost:8080/GoodMan/ChatService");
}
else {
alert('當前瀏覽器 Not support websocket')
}
//連接成功建立的回調方法
websocket.onopen = function () {
alert("WebSocket連接成功");
}
//連接發生錯誤的回調方法
websocket.onerror = function () {
alert("WebSocket連接發生錯誤");
};
//發送消息
function sendMess(content) {
var json ="{'username':'"+'${sessionScope.username }'+"', 'content':'"+content+"'}";
websocket.send(json);
}
//接收到消息的回調方法
websocket.onmessage = function (event) {
var jsonString = event.data; //接收到的信息存放在event.data中
var data = JSON.parse(jsonString); //將json字符串轉換成js對象
// 然后輸出data
}
//連接關閉的回調方法
websocket.onclose = function () {
alert("WebSocket連接關閉");
}
//監聽窗口關閉事件,當窗口關閉時,主動去關閉websocket連接,防止連接還沒斷開就關閉窗口,server端會拋異常。
window.onbeforeunload = function () {
closeWebSocket();
}
//關閉WebSocket連接
function closeWebSocket() {
websocket.close();
}
二.服務器
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 { //每進入一個用戶,就新建一個ChatService對象
private static int onlineCount = 0; //靜態變量, 用來記錄當前在線連接數
private static Set<ChatService> webSocketSet = new HashSet<>(); //靜態變量,用來存放在線用戶
private Session session; //用于存儲與該用戶的會話,要通過它來給客戶端發送數據
/**
* 連接建立成功調用的方法
* @param session 可選的參數。session為與某個客戶端的連接會話,需要通過它來給客戶端發送數據
*/
@OnOpen
public void onOpen(Session session){
this.session = session;
webSocketSet.add(this); //加入set中
addOnlineCount(); //在線數加1
System.out.println("有新連接加入!當前在線人數為" + getOnlineCount());
}
/**
* 連接關閉調用的方法
*/
@OnClose
public void onClose(){
webSocketSet.remove(this); //從set中刪除
subOnlineCount(); //在線數減1
System.out.println("有一連接關閉!當前在線人數為" + getOnlineCount());
}
/**
* 收到客戶端消息后調用的方法
* @param message 客戶端發送過來的消息
* @param session 可選的參數
*/
@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());
//群發消息
for(ChatService item: webSocketSet){
try {
item.sendMessage(mess);
} catch (IOException e) {
e.printStackTrace();
continue;
}
}
}
/**
* 發生錯誤時調用
* @param session
* @param error
*/
@OnError
public void onError(Session session, Throwable error){
System.out.println("發生錯誤");
error.printStackTrace();
}
//以下為輔助函數
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); //將消息對象轉換成json字符串
this.session.getAsyncRemote().sendText(jsonInfo); //通過session異步地將信息發送到客戶端上
}
public static synchronized int getOnlineCount() {
return onlineCount;
}
public static synchronized void addOnlineCount() {
ChatService.onlineCount++;
}
public static synchronized void subOnlineCount() {
ChatService.onlineCount--;
}
}以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持創新互聯。
當前題目:WebSocket實現Web聊天室功能
地址分享:http://www.yijiale78.com/article4/pcpjoe.html
成都網站建設公司_創新互聯,為您提供靜態網站、品牌網站制作、搜索引擎優化、建站公司、營銷型網站建設、網站設計
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯