React+WebSocket+SpringBoot简单demo

1. 引入依赖

    <dependency>
        <groupId>org.apache.tomcat.embed</groupId>
        <artifactId>tomcat-embed-websocket</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-websocket</artifactId>
    </dependency>

2. 编写config

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.socket.server.standard.ServerEndpointExporter;

/*
* websocket连接,如果不需要可以关闭
* */
@Configuration
public class WebSocketConfig {
    @Bean
    public ServerEndpointExporter serverEndpointExporter() {
        return new ServerEndpointExporter();
    }
}

3. 配置Server

import lombok.extern.slf4j.Slf4j;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Component;
import javax.annotation.Resource;
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.TimeUnit;
import java.util.concurrent.atomic.AtomicInteger;

/**
 * 连接步骤
 * 返回单个数据
 */

@ServerEndpoint( value = "/websocket/{user_id}" )
@Component
@Slf4j
public class WebSocketServer {
    private static Logger L = LoggerFactory.getLogger(WebSocketServer.class);
    private String userId;
   
    /**
     * 建立连接
     *
     * @param session
     */
    @OnOpen
    public void onOpen(Session session, @PathParam( "user_id" ) String userId) {
        this.userId = userId;
        log.info("ok");
    }

    /**
     * 关闭连接
     */
    @OnClose
    public void onClose() {
        log.info("关闭连接");
    }

    /**
     * 发送消息
     *
     * @param message
     * @param session
     */
    @OnMessage
    public void onMessage(String message, Session session) {
        try {
                session.getBasicRemote().sendText("消息收到");
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

4. React编写

import React, { useState, useEffect } from 'react';

const Message: React.FC = () => {
  const [socket, setSocket] = useState<WebSocket | null>(null);
  const [message, setMessage] = useState('');
  const [receiveMessage, setReceiveMessage] = useState('');

  useEffect(() => {
    // 创建 WebSocket 连接
    const url = 'ws://localhost:8101/api/websocket/1';
    const ws = new WebSocket(url);
    // 保存 WebSocket 对象到状态中
    setSocket(ws);

    // 监听 WebSocket 连接的打开事件
    ws.onopen = () => {
      console.log('WebSocket 连接已打开');
    };

    // 监听 WebSocket 接收消息事件
    ws.onmessage = (event) => {
      const receivedMessage = event.data;
      setReceiveMessage(receivedMessage);
      console.log('接收到消息:', receivedMessage);
    };

    // 监听 WebSocket 连接关闭事件
    ws.onclose = () => {
      console.log('WebSocket 连接已关闭');
    };

    // 在组件卸载时关闭 WebSocket 连接
    return () => {
      ws.close();
    };
  }, []);

  const sendMessage = () => {
    if (socket && message) {
      // 发送消息到 WebSocket 服务器
      socket.send(message);
    }
  };

  const handleInputChange = (event: React.ChangeEvent<HTMLInputElement>) => {
    setMessage(event.target.value);
  };

  return (
    <div>
      <input type="text" value={receiveMessage} readOnly />
      <input type="text" value={message} onChange={handleInputChange} />
      <button onClick={sendMessage}>发送</button>
    </div>
  );
};
export default Message;

5. 展示运行

建立连接在这里插入图片描述
在这里插入图片描述
发送消息
在这里插入图片描述
在这里插入图片描述

总结

以上就是简单的WebSocket实现。后续将会优化界面。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

flybase

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值