嵌入式tomcat 8.0.21中的Spring websocket

时间:2016-08-29 13:26:22

标签: java spring tomcat websocket

我想基于一个例子创建一个WebSocket。唯一的转折是我在嵌入式tomcat中运行我的应用程序。

package com.test.websocket;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.web.socket.CloseStatus;
import org.springframework.web.socket.TextMessage;
import org.springframework.web.socket.WebSocketSession;
import org.springframework.web.socket.handler.AbstractWebSocketHandler;

public class WebSocketTest extends AbstractWebSocketHandler {
    private static Logger logger = LoggerFactory.getLogger(WebSocketTest.class);

    @Override
    protected void handleTextMessage(WebSocketSession session, TextMessage message) throws Exception {
        logger.debug("Recieved websocket message: " + message);

        session.sendMessage(new TextMessage("thanks"));
    }

    @Override
    public void afterConnectionEstablished(WebSocketSession session) throws Exception {
        logger.info("WebSocket connection established!");
    }

    @Override
    public void afterConnectionClosed(WebSocketSession session, CloseStatus status) throws Exception {
        logger.info("WebSocket connection closed!");
    }
}

配置(websocket.spring.xml):

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:websocket="http://www.springframework.org/schema/websocket"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
              http://www.springframework.org/schema/beans/spring-beans.xsd
              http://www.springframework.org/schema/websocket
              http://www.springframework.org/schema/websocket/spring-websocket.xsd">

       <websocket:handlers>
              <websocket:mapping path="/socket" handler="webSocketHandler"/>
       </websocket:handlers>

       <bean id="webSocketHandler" class="com.test.websocket.WebSocketTest"/>
</beans>

Servlet映射位于/ websocket / *

从日志看起来spring-websocket似乎已成功初始化,但是当我尝试连接到websocket时,我收到此错误。

Servlet.service() for servlet [spring-websocket] in context with path [] threw exception [Request processing failed; nested exception is org.springframework.web.socket.server.HandshakeFailureException: Uncaught failure for request http://localhost:9876/websocket/socket; nested exception is java.lang.IllegalArgumentException: No 'javax.websocket.server.ServerContainer' ServletContext attribute. Are you running in a Servlet container that supports JSR-356?] with root cause

依赖关系是:tomcat-embed-core,tomcat-embed-websocket,tomcat-juli和因为(Spring websocket example - error - Are you running in a Servlet container that supports J SR-356?)javax.websocket-api和tomcat-websocket

我错过了什么?

提前致谢!

1 个答案:

答案 0 :(得分:3)

也许我找到了解决问题的方法。

您需要将WsSci servlet容器初始化程序用于嵌入式tomcat上下文:

context.addServletContainerInitializer(new WsSci(),null);

https://github.com/spring-projects/spring-boot/issues/439