wuxw
2022-05-10 8f61316069a6ffffb0998ed3f498bd4e3acc77e4
service-api/src/main/java/com/java110/api/websocket/MessageWebsocket.java
@@ -5,14 +5,10 @@
import com.java110.utils.util.StringUtil;
import com.java110.vo.ResultVo;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import com.java110.core.log.LoggerFactory;
import org.springframework.stereotype.Component;
import javax.websocket.OnClose;
import javax.websocket.OnError;
import javax.websocket.OnMessage;
import javax.websocket.OnOpen;
import javax.websocket.Session;
import javax.websocket.*;
import javax.websocket.server.PathParam;
import javax.websocket.server.ServerEndpoint;
import java.io.IOException;
@@ -26,7 +22,7 @@
 * @Version 1.0
 * add by wuxw 2020/6/5
 **/
@ServerEndpoint("/ws/message/{userId}")
@ServerEndpoint("/ws/message/{userId}/{clientId}")
@Component
public class MessageWebsocket {
    private final static Logger logger = LoggerFactory.getLogger(MessageWebsocket.class);
@@ -54,14 +50,17 @@
     */
    private String userId = "";
    private String clientId = "";
    /**
     * 连接建立成功调用的方法
     */
    @OnOpen
    public void onOpen(Session session, @PathParam("userId") String userId) {
    public void onOpen(Session session, @PathParam("userId") String userId, @PathParam("clientId") String clientId) {
        this.session = session;
        this.userId = userId;
        this.clientId = clientId;
        if (webSocketMap.containsKey(userId)) {
            webSocketMap.remove(userId);
            webSocketMap.put(userId, this);
@@ -74,12 +73,12 @@
        }
        logger.debug("用户连接:" + userId + ",当前在线人数为:" + getOnlineCount());
        logger.debug("用户连接:" + userId + ",客户端:" + clientId + ",当前在线人数为:" + getOnlineCount());
        try {
            sendMessage("连接成功");
        } catch (IOException e) {
            logger.error("用户:" + userId + ",网络异常!!!!!!");
            logger.error("用户:" + userId + ",客户端:" + clientId + ",网络异常!!!!!!");
        }
    }
@@ -93,7 +92,7 @@
            //从set中删除
            subOnlineCount();
        }
        logger.info("用户退出:" + userId + ",当前在线人数为:" + getOnlineCount());
        logger.info("用户退出:" + userId + ",客户端:" + clientId + ",当前在线人数为:" + getOnlineCount());
    }
    /**
@@ -103,7 +102,7 @@
     */
    @OnMessage
    public void onMessage(String message, Session session) throws IOException {
        logger.info("用户消息:" + userId + ",报文:" + message);
        logger.info("用户消息:" + userId + ",客户端:" + clientId + ",报文:" + message);
        //可以群发消息
        //消息保存到数据库、redis
        if (StringUtil.isEmpty(message)) {
@@ -120,9 +119,9 @@
        WsDataDto wsDataDto = JSONObject.parseObject(message, WsDataDto.class);
        switch (wsDataDto.getCmd()){
        switch (wsDataDto.getCmd()) {
            case WsDataDto.CMD_PING:
                webSocketMap.get(userId).sendMessage(wsDataDto.toString());
                //webSocketMap.get(userId).sendMessage(wsDataDto.toString());
                break;
        }
@@ -148,8 +147,8 @@
     */
    @OnError
    public void onError(Session session, Throwable error) {
        logger.error("用户错误:" + this.userId + ",原因:" + error.getMessage());
        error.printStackTrace();
        logger.error("用户错误:" + this.userId + ",客户端:" + clientId + ",原因:" + error.getMessage());
        // error.printStackTrace();
    }
    /**
@@ -165,10 +164,11 @@
     */
    public static void sendInfo(String message, String userId) throws IOException {
        logger.info("发送消息到:" + userId + ",报文:" + message);
        if (!webSocketMap.containsKey(userId)) {
            //客户端未连接
            return;
        }
        webSocketMap.get(userId).sendMessage(message);
    }
    public static synchronized int getOnlineCount() {