|
| 1 | +package cn.netbuffer.springboot.websocket.demo.websocket.handler; |
| 2 | + |
| 3 | +import lombok.extern.slf4j.Slf4j; |
| 4 | +import org.springframework.web.socket.*; |
| 5 | +import org.springframework.web.socket.handler.AbstractWebSocketHandler; |
| 6 | + |
| 7 | +@Slf4j |
| 8 | +public class MessageHandler extends AbstractWebSocketHandler { |
| 9 | + |
| 10 | + @Override |
| 11 | + public void afterConnectionEstablished(WebSocketSession session) throws Exception { |
| 12 | + super.afterConnectionEstablished(session); |
| 13 | + SessionManager.put(session.getId(), session); |
| 14 | + log.info("session[{}] afterConnectionEstablished", session.getId()); |
| 15 | + } |
| 16 | + |
| 17 | + @Override |
| 18 | + public void afterConnectionClosed(WebSocketSession session, CloseStatus status) throws Exception { |
| 19 | + log.info("session[{}] afterConnectionClosed", session.getId()); |
| 20 | + SessionManager.remove(session.getId()); |
| 21 | + } |
| 22 | + |
| 23 | + @Override |
| 24 | + protected void handleTextMessage(WebSocketSession session, TextMessage message) throws Exception { |
| 25 | + log.info("session[{}] receive text message={}", session.getId(), message); |
| 26 | + } |
| 27 | + |
| 28 | + @Override |
| 29 | + protected void handleBinaryMessage(WebSocketSession session, BinaryMessage message) throws Exception { |
| 30 | + log.info("session[{}] receive binary message={} length={}", session.getId(), message, message.getPayloadLength()); |
| 31 | + } |
| 32 | + |
| 33 | + @Override |
| 34 | + protected void handlePongMessage(WebSocketSession session, PongMessage message) throws Exception { |
| 35 | + log.info("session[{}] receive pong message={}", session.getId(), message); |
| 36 | + } |
| 37 | + |
| 38 | + @Override |
| 39 | + public void handleTransportError(WebSocketSession session, Throwable exception) throws Exception { |
| 40 | + } |
| 41 | + |
| 42 | +} |
0 commit comments