SpringBoot Websocket 集成

maven

        
            org.springframework.boot
            spring-boot-starter-websocket
        

config文件

@Configuration
public class WebSocketConfig {
    @Bean
    public ServerEndpointExporter serverEndpointExporter() {
        return new ServerEndpointExporter();
    }

}

demo

@Slf4j
@ServerEndpoint(value="/demo")
@Component
public class FrameSyncWebsocket {
    //静态变量,用来记录当前在线连接数。应该把它设计成线程安全的。
    private static int onlineCount = 0;
    //concurrent包的线程安全Set,用来存放每个客户端对应的MyWebSocket对象。
    private static CopyOnWriteArraySet webSocketSet = new CopyOnWriteArraySet();

    //与某个客户端的连接会话,需要通过它来给客户端发送数据
    private Session session;

    /**
     * 连接建立成功调用的方法*/
    @OnOpen
    public void onOpen(Session session) {
        this.session = session;
        webSocketSet.add(this);     //加入set中
        addOnlineCount();           //在线数加1
        log.info("有新连接加入!当前在线人数为" + getOnlineCount());
        try {
            sendMessage("连接成功");
        } catch (IOException e) {
            log.error("websocket IO异常");
        }
    }


    /**
     * 连接关闭调用的方法
     */
    @OnClose
    public void onClose() {
        webSocketSet.remove(this);  //从set中删除
        subOnlineCount();           //在线数减1
        log.info("有一连接关闭!当前在线人数为" + getOnlineCount());
    }

    /**
     * 收到客户端消息后调用的方法
     *
     * @param message 客户端发送过来的消息*/
    @OnMessage
    public void onMessage(String message, Session session) {
        log.info("来自客户端的消息:" + message);

        //群发消息
        for (FrameSyncWebsocket item : webSocketSet) {
            try {
                item.sendMessage(message);
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
    }

    /**
     *
     * @param session
     * @param error
     */
    @OnError
    public void onError(Session session, Throwable error) {
        log.error("发生错误");
        error.printStackTrace();
    }


    public void sendMessage(String message) throws IOException {
        this.session.getBasicRemote().sendText(message);
    }


    /**
     * 群发自定义消息
     * */
    public static void sendInfo(String message) throws IOException {
        log.info(message);
        for (FrameSyncWebsocket item : webSocketSet) {
            try {
                item.sendMessage(message);
            } catch (IOException e) {
                continue;
            }
        }
    }

    public static synchronized int getOnlineCount() {
        return onlineCount;
    }

    public static synchronized void addOnlineCount() {
        FrameSyncWebsocket.onlineCount++;
    }

    public static synchronized void subOnlineCount() {
        FrameSyncWebsocket.onlineCount--;
    }

}

超级简化demo

@Component
@Slf4j
@ServerEndpoint("/server")
public class FrameWebsocket {

    @OnOpen
    public void onOpen(Session session){
        System.out.println("new connection");
        System.out.println(session.getId());
    }

}

剩余几个事件(onClose等等)注解看上面的例子

js最简单写法

function openWebsocket()
{
   if ("WebSocket" in window)
   {
      
      // 打开一个 web socket
      var ws = new WebSocket("ws://localhost:8080/server");
       
      ws.onopen = function()
      {
         // Web Socket 已连接上,使用 send() 方法发送数据
         ws.send("发送数据");
      };
       
      ws.onmessage = function (evt) 
      { 
         var received_msg = evt.data;
      };
       
      ws.onclose = function()
      { 
         // 关闭 websocket
         alert("连接已关闭..."); 
      };
   }
   
   else
   {
      // 浏览器不支持 WebSocket
      alert("您的浏览器不支持 WebSocket!");
   }
}

你可能感兴趣的:(SpringBoot Websocket 集成)