Tomcat发布websocket

一、tomcal的lib放入文件

tomcat-websocket.jar

websocket-api.jar

二、代码示例

复制代码
package com.test.ws;

import com.test.core.json.Jmode;

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

/**
 * Created by 51594 on 2024/3/18.
 */
@ServerEndpoint("/ws/test")
public class WsTest {


    //静态变量,用来记录当前在线连接数。
    private static AtomicInteger onlineCount = new AtomicInteger(0);

    //concurrent包的线程安全Set,用来存放每个客户端对应的MyWebSocket对象。
    // 若要实现服务端与单一客户端通信的话,可以使用Map来存放,其中Key可以为用户标识
    //单一对话
    //
    // private static ConcurrentHashMap<String, TestController> guestSet = new ConcurrentHashMap<String, TestController>();
    //广播
    protected static CopyOnWriteArraySet<WsTest> guestSet = new CopyOnWriteArraySet<WsTest>();

    //与某个客户端的连接会话,需要通过它来给客户端发送数据
    private Session session;

    private int user_id = 0;

    private String user_name = "";


    @OnOpen
    public void onOpen(Session session) {
        // System.out.println(session.getMessageHandlers().);
        System.out.println("新客人为" + session.getId());
        this.session = session;
        guestSet.add(this);//加入map中
        addOnlineCount();           //在线数加1
        System.out.println("有新连接" + session.getId() + "加入!当前在线人数为" + getOnlineCount());
    }

    @OnClose
    public void onClose(Session session) {
        guestSet.remove(this);  //从set中删除
        subOnlineCount();           //在线数减1
        System.out.println("有一连接关闭!当前在线人数为" + getOnlineCount());
    }

    public static int getOnlineCount() {
        return onlineCount.get();
    }

    public static void addOnlineCount() {
        onlineCount.incrementAndGet();
    }

    public static void subOnlineCount() {
        onlineCount.decrementAndGet();
    }

    /**
     * 发生错误时调用
     *
     * @param session
     * @param error
     */
    @OnError
    public void onError(Session session, Throwable error) {
        System.out.println("发生错误");
        error.printStackTrace();
    }

    /**
     * @param msg
     * @param session
     */
    @OnMessage
    public void onMessage(String msg, Session session) {
        System.out.println("session----" + session);
        System.out.println("req----" + msg);
        try {
            session.getBasicRemote().sendText(Jmode.n().set("msg", msg).toJson());
            for (WsTest t : guestSet) {
                t.session.getBasicRemote().sendText(Jmode.n().set("id", session.getId()).set("msg", msg).toJson());
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

三、nginx配置:

复制代码
	location /salews/ {
        	proxy_pass              http://localhost:8001/sale/ws/;
		proxy_http_version 1.1;
		proxy_set_header Upgrade $http_upgrade;
		proxy_set_header Connection "Upgrade";
		proxy_set_header Host $host;
		proxy_read_timeout 86400;
		proxy_set_header X-Real-IP $remote_addr;
		proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

		proxy_set_header Access-Control-Allow-Methods *;
	}
相关推荐
程序员张32 小时前
Maven编译和打包插件
java·spring boot·maven
ybq195133454313 小时前
Redis-主从复制-分布式系统
java·数据库·redis
weixin_472339464 小时前
高效处理大体积Excel文件的Java技术方案解析
java·开发语言·excel
小毛驴8504 小时前
Linux 后台启动java jar 程序 nohup java -jar
java·linux·jar
DKPT5 小时前
Java桥接模式实现方式与测试方法
java·笔记·学习·设计模式·桥接模式
你想考研啊6 小时前
三、jenkins使用tomcat部署项目
运维·tomcat·jenkins
好奇的菜鸟6 小时前
如何在IntelliJ IDEA中设置数据库连接全局共享
java·数据库·intellij-idea
IT乌鸦坐飞机6 小时前
nignx+Tomcat+NFS负载均衡加共享储存服务脚本
tomcat·centos7·nfs·nignx
DuelCode7 小时前
Windows VMWare Centos Docker部署Springboot 应用实现文件上传返回文件http链接
java·spring boot·mysql·nginx·docker·centos·mybatis
优创学社27 小时前
基于springboot的社区生鲜团购系统
java·spring boot·后端