实战 WebSocket 实现双向通讯

一、添加依赖

<dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-websocket</artifactId>
        </dependency>
        <!--websocket-->
        <dependency>
            <groupId>io.goeasy</groupId>
            <artifactId>goeasy-sdk</artifactId>
            <version>0.4.2</version>
        </dependency>

二、具体步骤

  1. 建立连接:通过调用 WebSocket 对象的 open() 方法来建立与服务器的连接。

  2. 发送数据:通过调用 WebSocket 对象的 send() 方法来向服务器发送数据。

  3. 接收数据:通过 WebSocket 对象的 onmessage 事件来接收服务器发送回来的数据。

  4. 关闭连接:通过调用 WebSocket 对象的 close() 方法来关闭与服务器的连接

三、代码实例 

@Configuration
@EnableWebSocket
public class WebSocketConfig implements WebSocketConfigurer {

    //建立两个链接
    private final MyWebSocketHandler myWebSocketHandler;
    private final MyWebSocketHandler1 myWebSocketHandler1;


    public WebSocketConfig(MyWebSocketHandler myWebSocketHandler, MyWebSocketHandler1 myWebSocketHandler1) {
        this.myWebSocketHandler = myWebSocketHandler;
        this.myWebSocketHandler1 = myWebSocketHandler1;
    }

    @Override
    public void registerWebSocketHandlers(WebSocketHandlerRegistry registry) {
        //分别监听不同的实例
        registry.addHandler(myWebSocketHandler, "/websocket")
                .setAllowedOrigins("*");
        registry.addHandler(myWebSocketHandler1, "/websocket2")
                .setAllowedOrigins("*");
    }
}

 这里以监听字符串为例子(可以选择监听文件等)

@Component
public class MyWebSocketHandler extends TextWebSocketHandler {
    private WebSocketSession session;
    public static String logContent = ""; // 字符串内容
    private long lastLength = 0; // 上次记录的字符串长度


    @Override
    public void afterConnectionEstablished(WebSocketSession session){
        // 处理WebSocket连接建立的逻辑
        this.session = session;

        // 启动字符串监控线程
        Thread stringMonitoringThread = new Thread(() -> {
            while (true) {
                if (logContent.length() > lastLength) {
                    String modifiedContent = logContent.substring((int) lastLength); // 获取新增的字符串内容
                    try {
                        session.sendMessage(new TextMessage(modifiedContent)); // 发送新增的内容到前台
                        logContent="";
                    } catch (IOException e) {
                        throw new RuntimeException(e);
                    }
                    lastLength = logContent.length(); // 更新上次记录的字符串长度
                }
                try {
                    Thread.sleep(1000); // 每隔一秒检查一次
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }
        });
        stringMonitoringThread.start(); // 启动字符串监控线程
    }

    @Override
    protected void handleTextMessage(WebSocketSession session, TextMessage message) throws Exception {
        // 处理接收到的WebSocket消息的逻辑
        System.out.println("接收到WebSocket消息:" + message.getPayload());
    }

    @Override
    public void afterConnectionClosed(WebSocketSession session, CloseStatus status) throws Exception {
        // 处理WebSocket连接关闭的逻辑
        System.out.println("WebSocket连接已关闭");
    }


}

模拟用法

 @PostMapping("/send")
    public void send(@RequestBody SourceTypeResponse sourceTypeResponse){
        log.info(JSONObject.toJSONString(sourceTypeResponse));
        
        if (sourceTypeResponse.getPageNum()==1){
            MyWebSocketHandler.logContent= "警告";
        }

    }

四、前台展示 

mounted() {
			const socket = new WebSocket('ws://127.0.0.1:8087/websocket')
			socket.onopen = () => {
				console.log('WebSocket连接已建立')
			}
			socket.onmessage = event => {
				const logMessage = event.data
				console.log(logMessage)
				this.logs.push(logMessage) // 将日志消息存储到数组中
			}

			socket.onclose = () => {
				console.log('WebSocket连接已关闭')
			}

			socket.onerror = error => {
				console.error('WebSocket发生错误:', error)
			}
    },
<div>
		<h1>WebSocket日志</h1>
		<ul>
			<li v-for="log in logs" :key="log">{{ log }}</li>
		</ul>
	</div>

五、效果展示

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
WebSocket是一种支持双向通信的网络协议,可以在客户端和服务器之间建立实时的、持久的连接。它通过在HTTP协议升级到WebSocket协议的过程中握手来建立连接,并使用类似Socket的API来进行通信。 要实现WebSocket的即时通讯,需要以下步骤: 1. 客户端发起WebSocket连接请求:客户端通过发送HTTP请求到服务器来建立WebSocket连接。请求头中需要包含特定的字段来指示升级到WebSocket协议。 2. 服务器接受WebSocket连接请求:服务器接收到客户端的WebSocket连接请求后,会返回特定的响应头,表示成功升级到WebSocket协议。 3. 双向通信:建立WebSocket连接后,客户端和服务器可以通过发送消息来进行实时的双向通信。客户端和服务器都可以主动发送消息,并且对方可以通过事件监听来接收消息。 4. 关闭连接:当通信完成或者需要关闭连接时,客户端或服务器可以发送关闭帧来结束WebSocket连接。 对于客户端来说,可以使用浏览器提供的JavaScript WebSocket API来实现WebSocket的功能。具体步骤如下: 1. 创建WebSocket对象:在JavaScript中创建一个WebSocket对象,指定要连接的服务器地址。 2. 监听事件:通过监听WebSocket对象的事件来接收服务器发送的消息。常用的事件有onopen(连接建立)、onmessage(收到消息)、onclose(连接关闭)和onerror(连接错误)。 3. 发送消息:使用WebSocket对象的send()方法来向服务器发送消息。 对于服务器端来说,可以使用各种编程语言提供的WebSocket库来实现WebSocket的功能。具体步骤如下: 1. 接受连接:服务器端需要监听客户端发起的连接请求,并接受连接。 2. 响应升级请求:服务器端需要返回特定的响应头来表示成功升级到WebSocket协议。 3. 处理消息:服务器端可以通过监听接收到的消息来处理客户端发送的消息,并根据需求进行相应的操作。 4. 发送消息:服务器端可以使用相应的方法来向客户端发送消息。 以上就是使用WebSocket实现即时通讯的基本步骤,具体实现方式会根据具体的编程语言和框架而有所不同。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值