package com.se.system.service; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.stereotype.Component; import javax.annotation.PostConstruct; import javax.websocket.*; import javax.websocket.server.ServerEndpoint; import java.io.IOException; import java.util.concurrent.CopyOnWriteArraySet; import java.util.concurrent.atomic.AtomicInteger; @Component @SuppressWarnings("ALL") @ServerEndpoint(value = "/ws/query") public class WebSocketService { @PostConstruct public void init() { System.out.println("websocket 加载完成"); } private static final Logger log = LoggerFactory.getLogger(WebSocketService.class); private static final AtomicInteger ONLINE_COUNT = new AtomicInteger(0); private final static CopyOnWriteArraySet SESSION_SET = new CopyOnWriteArraySet(); @OnOpen public void onOpen(Session session) { SESSION_SET.add(session); int cnt = ONLINE_COUNT.incrementAndGet(); log.info("有连接加入,当前连接数为:{}", cnt); sendMessage(session, "连接成功"); } @OnClose public void onClose(Session session) { SESSION_SET.remove(session); int cnt = ONLINE_COUNT.decrementAndGet(); log.info("有连接关闭,当前连接数为:{}", cnt); } @OnMessage public void onMessage(String message, Session session) { log.info("来自客户端的消息:{}", message); sendMessage(session, "收到消息,消息内容:" + message); } @OnError public void onError(Session session, Throwable error) { log.error("发生错误:{},Session ID: {}", error.getMessage(), session.getId()); } public static void sendMessage(Session session, String message) { try { session.getBasicRemote().sendText(String.format("%s", message)); } catch (Exception ex) { log.error("发送消息出错:{}", ex.getMessage()); } } public static void broadCastInfo(String message) throws IOException { for (Session session : SESSION_SET) { if (session.isOpen()) { sendMessage(session, message); } } } public static void sendMessage(String message, String sessionId) throws IOException { Session session = null; for (Session s : SESSION_SET) { if (s.getId().equals(sessionId)) { session = s; break; } } if (session != null) { sendMessage(session, message); } else { log.info("没有找到你指定ID的会话:{}", sessionId); } } }