spring websocket简单搭建

最近做项目用到web长连接所以用到 spring websocket。在spring中websocket的实现非常简单。

首先在spring项目中加入jar包spring-websocket包,或maven中加入
jar包版本根据自己spring版本决定

org.springframework
spring-websocket
${org.springframework-version}


/**
*spring websocket配置类
*/

@Configuration
@EnableWebMvc
@EnableWebSocket
public class WebConfig implements WebSocketConfigurer {

    /**
    *路由处理
    */
    @Override
    public void registerWebSocketHandlers(WebSocketHandlerRegistry registry) {
        //从ws://ip:端口/项目/echo 来的所有请求由   
        //simpleWebSocketHandler来处理 
        registry.addHandler(simpleWebSocketHandler(), "/echo");
    }

    @Bean
    public SimpleWebSocketHandler simpleWebSocketHandler() {
        return new SimpleWebSocketHandler();
    }

}


/**
*消息处理类
*/
public class SimpleWebSocketHandler implements WebSocketHandler {

    /**
     * 连接前处理
     */
    @Override
    public void afterConnectionEstablished(WebSocketSession session) throws Exception {
        //session.sendMessage(new TextMessage(JSON.toJSONString("")));
    }

    /**
     * 消息处理
     */
    @Override
    public void handleMessage(WebSocketSession session, WebSocketMessage<?> message)
            throws Exception {
        System.out.println("消息处理 :" + message.getPayload());
        session.sendMessage(new TextMessage("回复消息:" + message.getPayload()));

    }

    /**
     * 错误处理
     */
    @Override
    public void handleTransportError(WebSocketSession session, Throwable exception)
            throws Exception {
        System.out.println("传输错误");
    }

    /**
     * 连接关闭后处理事件
     */
    @Override
    public void afterConnectionClosed(WebSocketSession session, CloseStatus closeStatus)
            throws Exception {
        System.out.println("连接关闭:");
    }

    @Override
    public boolean supportsPartialMessages() {
        return false;
    }
}

js代码

var URL = 'ws://' + window.location.host + "/test/echo";
//创建一个Socket实例
var ws = new WebSocket(URL);
console.log(URL);

ws.onopen = function(e) {
    console.info("打开连接");
};

ws.onmessage = function(e) {
    console.log(e.data);
};

ws.onclose = function() {
    // setConnected(false);
    console.log("连接关闭");
};

//消息发送
ws.send("123");


//*注意点:js端不能在加载页面后立即发送消息,否则会报异常(因为socket还在初始化中,没有建产连接)。在发送消息前应先判断连接状态。

 if (ws.onopen) {
    console.log('已连接');
}


  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值