搭建一个简单的websocket的demo

首先,用idea搭建一个springboot项目

如此如此就不需要演示了把

接下来pom文件引入websocket依赖

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

然后,配置websocket,把websocket加入IOC容器

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

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

OK,然后咱们继续写websocket的服务端

  1. @ServerEndpoint(value = "/ws/asset")表示websocket的接口服务地址
  2. @OnOpen注解的方法,为连接建立成功时调用的方法
  3. @OnClose注解的方法,为连接关闭调用的方法
  4. @OnMessage注解的方法,为收到客户端消息后调用的方法
  5. @OnError注解的方法,为出现异常时调用的方法
import lombok.extern.slf4j.Slf4j;
import org.springframework.stereotype.Component;

import javax.websocket.*;
import javax.websocket.Session;
import javax.websocket.server.ServerEndpoint;
import java.io.IOException;
import java.util.concurrent.CopyOnWriteArraySet;
import java.util.concurrent.atomic.AtomicInteger;

/**
 * WebSocket服务端示例
 */
@Component
@Slf4j
@ServerEndpoint(value = "/ws/asset")
public class WebSocketServer {

    private static final AtomicInteger OnlineCount = new AtomicInteger(0);
    // concurrent包的线程安全Set,用来存放每个客户端对应的Session对象。  
    private static CopyOnWriteArraySet<Session> SessionSet = new CopyOnWriteArraySet<>();


    /**
     * 连接建立成功调用的方法
     */
    @OnOpen
    public void onOpen(Session session) throws IOException {
        SessionSet.add(session);
        int cnt = OnlineCount.incrementAndGet(); // 在线数加1  
        log.info("有连接加入,当前连接数为:{}", cnt);
        SendMessage(session, "连接成功");
    }

    /**
     * 连接关闭调用的方法
     */
    @OnClose
    public void onClose(Session session) {
        SessionSet.remove(session);
        int cnt = OnlineCount.decrementAndGet();
        log.info("有连接关闭,当前连接数为:{}", cnt);
    }

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

    /**
     * 出现错误
     */


    public void onError(Session session, Throwable error) {
        log.error("发生错误:{},Session ID: {}", error.getMessage(), session.getId());
    }

    /**
     * 发送消息,实践表明,每次浏览器刷新,session会发生变化。
     *
     * @param session session
     * @param message 消息
     */
    private static void SendMessage(Session session, String message) throws IOException {

        session.getBasicRemote().sendText(String.format("%s (From Server,Session ID=%s)", message, session.getId()));

    }

    /**
     * 群发消息
     *
     * @param message 消息
     */
    public static void BroadCastInfo(String message) throws IOException {
        for (Session session : SessionSet) {
            if (session.isOpen()) {
                SendMessage(session, message);
            }
        }
    }

    /**
     * 指定Session发送消息
     *
     * @param sessionId sessionId
     * @param message   消息
     */
    public static void SendMessage(String sessionId, String message) throws IOException {
        Session session = null;
        for (Session s : SessionSet) {
            if (s.getId().equals(sessionId)) {
                session = s;
                break;
            }
        }
        if (session != null) {
            SendMessage(session, message);
        } else {
            log.warn("没有找到你指定ID的会话:{}", sessionId);
        }
    }

} 

服务端有了,那就还差前端了

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title>websocket测试</title>
    <style type="text/css">
        h3,h4{
            text-align:center;
        }
    </style>
</head>
<body>

<h3>WebSocket测试,在<span style="color:red">控制台</span>查看测试信息输出!</h3>
<h4>
    <br>
    http://localhost:8080/api/ws/sendOne?message=单发消息内容&id=none
    <br>
    http://localhost:8080/api/ws/sendAll?message=群发消息内容
</h4>

<h3>请输入要发送给服务器端的消息:</h3><br/>

<input id="text" type="text" />
<button onclick="sendToServer()">发送服务器消息</button>
<button onclick="closeWebSocket()">关闭连接</button>
<br>信息:<span id="message"></span>


<script type="text/javascript">
    let socket;
    if (typeof (WebSocket) == "undefined") {
        console.log("遗憾:您的浏览器不支持WebSocket");
    } else {
        socket = new WebSocket("ws://localhost:8080/ws/asset");
        //连接打开事件
        socket.onopen = function() {
            console.log("Socket 已打开");
            socket.send("消息发送测试(From Client)");
        };
        //收到消息事件
        socket.onmessage = function(msg) {
            document.getElementById('message').innerHTML += msg.data + '<br/>';
        };
        //连接关闭事件
        socket.onclose = function() {
            console.log("Socket已关闭");
        };
        //发生了错误事件
        socket.onerror = function() {
            alert("Socket发生了错误");
        }

        //窗口关闭时,关闭连接
        window.unload=function() {
            socket.close();
        };
    }

    //关闭连接
    function closeWebSocket(){
        socket.close();
    }

    //发送消息给服务器
    function sendToServer(){
        let message = document.getElementById('text').value;
        socket.send(message);
    }
</script>

</body>
</html>

点击run,跑一下把

当有一个客户端连接上,终端显示

继续

点击发送消息

点击关闭连接就会出现

OK,测试完毕

记得点个赞、留个关注啊亲

### 回答1: 好的。 建立一个 WebSocketdemo 示例的步骤如下: 1. 在服务器端安装 ws 模块: ```bash npm install --save ws ``` 2. 在服务器端创建一个 WebSocket 服务器: ```javascript const WebSocket = require('ws'); const wss = new WebSocket.Server({ port: 8080 }); wss.on('connection', (ws) => { console.log('新的连接已建立'); ws.on('message', (message) => { console.log(`收到消息:${message}`); }); ws.send('你好!已连接到服务器。'); }); ``` 3. 在客户端创建一个 WebSocket 客户端: ```javascript const socket = new WebSocket('ws://localhost:8080'); socket.onopen = () => { console.log('连接已建立'); socket.send('你好!我是客户端。'); }; socket.onmessage = (event) => { console.log(`收到消息:${event.data}`); }; socket.onclose = () => { console.log('连接已关闭'); }; ``` 这就是一个简单WebSocket 示例。希望这对你有帮助。 ### 回答2: WebSocket是一种基于TCP协议的全双工通信协议,它允许在单个连接上进行双向通信。下面我将以300字介绍如何构建一个WebSocket的示例。 首先,我们需要使用一个支持WebSocket的编程语言或框架来实现示例。常见的选择包括JavaScript的WebSocket API、Python的Tornado框架、Java的Spring框架等。这里我选择使用JavaScript的WebSocket API来展示示例。 在前端,我们可以在HTML文件中创建一个WebSocket对象,通过指定服务器的地址创建WebSocket连接: ``` var socket = new WebSocket('ws://server-address'); ``` 在后端,我们可以使用Node.js来创建一个WebSocket服务器,监听指定的端口,并处理WebSocket的连接请求: ``` const WebSocket = require('ws'); const wss = new WebSocket.Server({ port: 8080 }); wss.on('connection', function connection(ws) { ws.on('message', function incoming(message) { console.log('received: %s', message); }); ws.send('Hello, client!'); }); ``` 在示例中,当客户端与服务器建立WebSocket连接后,可以通过调用`send`方法向服务器发送消息,通过监听`message`事件来接收服务器发送的消息。服务器也可以通过调用`send`方法向客户端发送消息。 要运行示例,我们需要在本地搭建一个WebSocket服务器,并在浏览器中打开HTML文件来建立WebSocket连接。 通过这个示例,我们可以实现客户端和服务器之间的实时双向通信,使得数据的传输更加高效和即时。WebSocket的优点在于它能够降低网络延迟,减少数据传输的开销,并支持真正的双向通信。 以上就是关于如何构建一个WebSocket的示例的简要介绍,希望对你有所帮助! ### 回答3: WebSocket是一种在Web应用程序中实现双向通信的协议。通过WebSocket,客户端和服务器可以实时地交换数据。以下是一个简单WebSocketDemo: 首先,我们需要在服务器端创建一个WebSocket服务器。可以使用一些流行的编程语言和框架,如Node.js使用Socket.io库,或者Python使用Tornado库来实现。这里以Node.js为例: 1. 在服务器端,在命令行中安装Socket.io库:npm install socket.io 2. 在服务器端创建一个Node.js文件,导入Socket.io库并创建一个服务器对象: ```javascript const io = require('socket.io')(); io.on('connection', (socket) => { console.log('客户端已连接'); socket.on('message', (data) => { console.log('收到消息:', data); io.emit('message', data); }); }); io.listen(3000); console.log('WebSocket服务器已启动'); ``` 3. 在客户端,使用浏览器中提供的WebSocket API来与服务器建立连接并发送和接收消息。可以在HTML文件中添加以下代码: ```html <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>WebSocket Demo</title> </head> <body> <h1>WebSocket Demo</h1> <input type="text" id="messageInput" placeholder="输入消息"> <button onclick="sendMessage()">发送</button> <ul id="messageList"></ul> <script> const socket = new WebSocket('ws://localhost:3000'); socket.onopen = function() { console.log('已连接到WebSocket服务器'); }; socket.onmessage = function(event) { const message = event.data; const listItem = document.createElement('li'); listItem.textContent = message; document.getElementById('messageList').appendChild(listItem); }; function sendMessage() { const input = document.getElementById('messageInput'); const message = input.value; socket.send(message); input.value = ''; } </script> </body> </html> ``` 以上代码通过创建一个WebSocket对象,并在与服务器成功建立连接后,监听消息的接收。当用户点击发送按钮时,JavaScript代码将用户输入的消息发送到服务器,并将服务器返回的消息添加到页面的消息列表中。 最后,可以运行服务器代码,在浏览器中打开HTML文件,就可以进行WebSocket测试和交互。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值