• springboot整合websocket


          <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-websocket</artifactId>
                <version>2.2.0.RELEASE</version>
            </dependency>
    @Component
    public class WebSocketConfig {
     
        /**
         * ServerEndpointExporter 作用
         *
         * 这个Bean会自动注册使用@ServerEndpoint注解声明的websocket endpoint
         *
         * @return
         */
        @Bean
        public ServerEndpointExporter serverEndpointExporter() {
            return new ServerEndpointExporter();
        }
    }
    package com.example.socket.code;
     
    import lombok.extern.slf4j.Slf4j;
    import org.springframework.stereotype.Component;
     
    import javax.websocket.OnClose;
    import javax.websocket.OnMessage;
    import javax.websocket.OnOpen;
    import javax.websocket.Session;
    import javax.websocket.server.PathParam;
    import javax.websocket.server.ServerEndpoint;
    import java.util.concurrent.ConcurrentHashMap;
     
    /**
     *
     * @ServerEndpoint 这个注解有什么作用?
     *
     * 这个注解用于标识作用在类上,它的主要功能是把当前类标识成一个WebSocket的服务端
     * 注解的值用户客户端连接访问的URL地址
     *
     */
     
    @Slf4j
    @Component
    @ServerEndpoint("/websocket/{name}")
    public class WebSocket {
     
        /**
         *  与某个客户端的连接对话,需要通过它来给客户端发送消息
         */
        private Session session;
     
         /**
         * 标识当前连接客户端的用户名
         */
        private String name;
     
        /**
         *  用于存所有的连接服务的客户端,这个对象存储是安全的
         */
        private static ConcurrentHashMap<String,WebSocket> webSocketSet = new ConcurrentHashMap<>();
     
     
        @OnOpen
        public void OnOpen(Session session, @PathParam(value = "name") String name){
            this.session = session;
            this.name = name;
            // name是用来表示唯一客户端,如果需要指定发送,需要指定发送通过name来区分
            webSocketSet.put(name,this);
            log.info("[WebSocket] 连接成功,当前连接人数为:={}",webSocketSet.size());
        }
     
     
        @OnClose
        public void OnClose(){
            webSocketSet.remove(this.name);
            log.info("[WebSocket] 退出成功,当前连接人数为:={}",webSocketSet.size());
        }
     
        @OnMessage
        public void OnMessage(String message){
            log.info("[WebSocket] 收到消息:{}",message);
            //判断是否需要指定发送,具体规则自定义
            if(message.indexOf("TOUSER") == 0){
                String name = message.substring(message.indexOf("TOUSER")+6,message.indexOf(";"));
                AppointSending(name,message.substring(message.indexOf(";")+1,message.length()));
            }else{
                GroupSending(message);
            }
     
        }
     
        /**
         * 群发
         * @param message
         */
        public void GroupSending(String message){
            for (String name : webSocketSet.keySet()){
                try {
                    webSocketSet.get(name).session.getBasicRemote().sendText(message);
                }catch (Exception e){
                    e.printStackTrace();
                }
            }
        }
     
        /**
         * 指定发送
         * @param name
         * @param message
         */
        public void AppointSending(String name,String message){
            try {
                webSocketSet.get(name).session.getBasicRemote().sendText(message);
            }catch (Exception e){
                e.printStackTrace();
            }
        }
    }
        @Autowired
        private  static KfbusineseService  kfbusineseService;
        @Autowired
        public void setChatService(KfbusineseService  kfbusineseService) {
            WebSocket.kfbusineseService = kfbusineseService;
        }
  • 相关阅读:
    JavaScript框架大战已结束,赢家只有一个
    js的作用域
    前端不缓存,ajax不缓存,js操作cookie
    7 款最棒的 React 移动端 UI 组件库 特别针对国内使用场景推荐
    变量提升与函数提升
    分享 11 张巨好看的PC端界面!!!
    C# 生成自签名CA证书
    2023年值得推荐的五大React Native UI库
    iPhone 返厂维修全记录
    macOS10.15安装qt出现 “无法打开“qtopensourcemacx645.13.2.app”,因为Apple无法检查其是否包含恶意软件。
  • 原文地址:https://www.cnblogs.com/sh-0131/p/12889595.html
Copyright © 2020-2023  润新知