Tomcat中WebSocket的使用

本文介绍了如何在Tomcat环境中创建并使用WebSocket进行实时通信。从后端代码的编写到前端应用的实现,展示了WebSocket的基本用法和项目集成步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

创建一个简单的Web项目,后端代码

import javax.websocket.*;
import javax.websocket.server.ServerEndpoint;
import java.io.IOException;
import java.util.Set;
import java.util.concurrent.CopyOnWriteArraySet;

@ServerEndpoint("/test")
public class SendMessageWebSocket {

    private Session session;

    private static final Set<SendMessageWebSocket> connections = new CopyOnWriteArraySet<>();

    static {
        new Thread(() -> {
            while (true) {
                for (SendMessageWebSocket connection : connections) {
                    try {
                        connection.session.getBasicRemote().sendText("你好,客户端!");
                        Thread.sleep(10000L);
                        // int i = 1 / 0;
                    } catch (Exception e) {
                        System.out.println("出现异常");
                        connections.remove(connection);
                        try {
                            connection.session.close();
                        } catch (IOException ioException) {
                            ioException.printStackTrace();
                        }
                    }
                }
            }
        }).start();
    }

    @OnOpen
    public void onOpen(Session session, EndpointConfig config) {
        this.session = session;
        connections.add(this);
        System.out.println("编号[" + session.getId() + "]" + "已连接");
    }

    @OnClose
    public void onClose(Session session, CloseReason closeReason) {
        connections.remove(this);
        System.out.println("编号[" + session.getId() + "]" + "已关闭");
    }

    @OnError
    public void onError(Session session, Throwable throwable) {
        System.out.println("onError" + throwable.getMessage());
    }

    @OnMessage
    public void echoTextMessage(Session session, String msg, boolean last) {
        System.out.println("收到消息:" + msg);
    }

}

前端代码

<%@ page contentType="text/html;charset=UTF-8" %>
<html>
<head>
    <title>WebSocket推送消息</title>
</head>
<body>
<input id="message" type="text" value="编辑消息"><br>
<button onclick="sendMsg()">发送</button>
<script>
    var ws = null;
    var target = "ws://127.0.0.1:8080/websocket/test";

    function connect() {
        ws = new WebSocket(target);
        ws.onopen = function () {
            console.log("已连接至服务器");
        };
        ws.onmessage = function (event) {
            console.log("收到服务器消息:" + event.data)
        };
        ws.onclose = function () {
            console.log("服务器连接已断开");
            connect();//断开继续连接
        };
        ws.onerror = function (event) {
            alert("onerror:" + event);
        };
    }

    function sendMsg() {
        ws.send(document.getElementById('message').value);
    }

    window.onload = function () {
        connect();
    }
</script>
</body>
</html>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值