中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

WebSocket實現Web聊天室功能

發布時間:2020-09-10 14:44:07 來源:腳本之家 閱讀:237 作者:DOLFAMINGO 欄目:編程語言

本文為大家分享了WebSocket實現Web聊天室的具體代碼,供大家參考,具體內容如下

一.客戶端

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--;
  }
}

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

甘孜县| 眉山市| 温州市| 兴和县| 炎陵县| 阳春市| 定安县| 乌什县| 太仓市| 鹿邑县| 岳西县| 河北省| 高碑店市| 黑水县| 琼海市| 中山市| 德清县| 集贤县| 密云县| 德庆县| 图们市| 定日县| 商都县| 崇州市| 灵武市| 东源县| 大荔县| 星座| 苏尼特左旗| 涟水县| 太和县| 安徽省| 海门市| 余干县| 佳木斯市| 通许县| 尚志市| 绥滨县| 芷江| 昌江| 神农架林区|