Подтвердить что ты не робот

Не удалось запустить демонстрацию веб-сокета spring

Я пытаюсь запустить демонстрацию веб-сокета spring, но не могу полностью его протестировать. Я использую java 7 и tomcat 7.0.50. Я не получаю никаких ошибок при запуске сервера, но когда я открываю веб-страницу с помощью js, связанного с ней, я получил 404 страницы, которые не были найдены. Я не уверен, что мне не хватает ничего в конфигурации, чтобы запустить его и как я могу подключить его со стороны js.

У меня есть следующий XML файл:

<beans ....>
    <context:annotation-config />

    <websocket:message-broker
        application-destination-prefix="/app">
        <websocket:stomp-endpoint path="/hello">
            <websocket:sockjs />
        </websocket:stomp-endpoint>
        <websocket:simple-broker prefix="/topic" />
    </websocket:message-broker>
</beans>

Мой класс контроллера:

@Controller
public class SwsService {
    @MessageMapping("/hello")
    @SendTo("/topic/greetings")
    public Greeting greeting(HelloMessage message) throws Exception {
         return new Greeting("Hello, " + message.getName() + "!");
   }

    public String getGreeting() {
        return "Hello, you are in!";
    }
}

js, из которого я вызываю это:

var sock = new SockJS("/hello");
sock.onopen = function () {
    console.log("open");
};
sock.onclose = function () {
    console.log("closed");
};
sock.onmessage = function (message) {
    console.log("msg", message);
};

Выход консоли при запуске tomcat:

Feb 19, 2014 3:28:47 PM org.apache.catalina.core.AprLifecycleListener init
INFO: The APR based Apache Tomcat Native library which allows optimal performance in production environments was not found on the java.library.path: C:\Program Files\Java\jre7\bin;C:\Windows\Sun\Java\bin;C:\Windows\system32;C:\Windows;C:/Program Files/Java/jre6/bin/client;C:/Program Files/Java/jre6/bin;C:/Program Files/Java/jre6/lib/i386;C:\Windows\system32;C:\Windows;C:\Windows\System32\Wbem;C:\Windows\System32\WindowsPowerShell\v1.0\;C:\Program Files\Intel\OpenCL SDK\2.0\bin\x86;C:\Program Files\TortoiseGit\bin;C:\Python24;C:\Program Files\TortoiseSVN\bin;C:\Program Files\nodejs\;C:\Program Files\Git\cmd;C:\Users\harsh\AppData\Roaming\npm;E:\IDE\eclipse_indigo;;.
Feb 19, 2014 3:28:47 PM org.apache.tomcat.util.digester.SetPropertiesRule begin
WARNING: [SetPropertiesRule]{Server/Service/Engine/Host/Context} Setting property 'source' to 'org.eclipse.jst.jee.server:SWS' did not find a matching property.
Feb 19, 2014 3:28:48 PM org.apache.coyote.AbstractProtocol init
INFO: Initializing ProtocolHandler ["http-bio-8080"]
Feb 19, 2014 3:28:48 PM org.apache.coyote.AbstractProtocol init
INFO: Initializing ProtocolHandler ["ajp-bio-8009"]
Feb 19, 2014 3:28:48 PM org.apache.catalina.startup.Catalina load
INFO: Initialization processed in 1412 ms
Feb 19, 2014 3:28:48 PM org.apache.catalina.core.StandardService startInternal
INFO: Starting service Catalina
Feb 19, 2014 3:28:48 PM org.apache.catalina.core.StandardEngine startInternal
INFO: Starting Servlet Engine: Apache Tomcat/7.0.50
Feb 19, 2014 3:28:51 PM org.apache.catalina.core.ApplicationContext log
INFO: No Spring WebApplicationInitializer types detected on classpath
Feb 19, 2014 3:28:51 PM org.apache.catalina.core.ApplicationContext log
INFO: Initializing Spring root WebApplicationContext
Feb 19, 2014 3:28:51 PM org.springframework.web.context.ContextLoader initWebApplicationContext
INFO: Root WebApplicationContext: initialization started
Feb 19, 2014 3:28:51 PM org.springframework.context.support.AbstractApplicationContext prepareRefresh
INFO: Refreshing Root WebApplicationContext: startup date [Wed Feb 19 15:28:51 IST 2014]; root of context hierarchy
Feb 19, 2014 3:28:52 PM org.springframework.beans.factory.xml.XmlBeanDefinitionReader loadBeanDefinitions
INFO: Loading XML bean definitions from ServletContext resource [/WEB-INF/classes/conf/SwsContext.xml]
Feb 19, 2014 3:28:53 PM org.springframework.scheduling.concurrent.ExecutorConfigurationSupport initialize
INFO: Initializing ExecutorService  'clientInboundChannelExecutor'
Feb 19, 2014 3:28:53 PM org.springframework.scheduling.concurrent.ExecutorConfigurationSupport initialize
INFO: Initializing ExecutorService  'clientOutboundChannelExecutor'
Feb 19, 2014 3:28:53 PM org.springframework.scheduling.concurrent.ExecutorConfigurationSupport initialize
INFO: Initializing ExecutorService  'messageBrokerSockJsScheduler'
Feb 19, 2014 3:28:53 PM org.springframework.web.servlet.handler.AbstractUrlHandlerMapping registerHandler
INFO: Mapped URL path [/hello/**] onto handler of type [class org.springframework.web.socket.sockjs.support.SockJsHttpRequestHandler]
Feb 19, 2014 3:28:53 PM org.springframework.context.support.DefaultLifecycleProcessor$LifecycleGroup start
INFO: Starting beans in phase 2147483647
Feb 19, 2014 3:28:53 PM org.springframework.web.context.ContextLoader initWebApplicationContext
INFO: Root WebApplicationContext: initialization completed in 2173 ms
Feb 19, 2014 3:28:53 PM org.apache.coyote.AbstractProtocol start
INFO: Starting ProtocolHandler ["http-bio-8080"]
Feb 19, 2014 3:28:53 PM org.apache.coyote.AbstractProtocol start
INFO: Starting ProtocolHandler ["ajp-bio-8009"]
Feb 19, 2014 3:28:53 PM org.apache.catalina.startup.Catalina start
INFO: Server startup in 5842 ms

Вывод консоли браузера:

GET http://localhost:8080/hello/info 404 (Not Found) sockjs-0.3.min.js:27
closed 

Как я могу успешно протестировать его?


Обновление

Я также попытался запустить пример портфеля отсюда: https://github.com/rstoyanchev/spring-websocket-portfolio, как было предложено @jhadesdev

Но это также не помогает. Когда я запускаю mvn tomcat7:run, я вижу следующий вывод, а открытый URL-адрес в браузере сообщает 404.

[INFO] Scanning for projects...
[INFO]
[INFO] Using the builder org.apache.maven.lifecycle.internal.builder.singlethrea
ded.SingleThreadedBuilder with a thread count of 1
[INFO]
[INFO] ------------------------------------------------------------------------
[INFO] Building spring-websocket-portfolio 1.0.0-SNAPSHOT
[INFO] ------------------------------------------------------------------------
[INFO]
[INFO] >>> tomcat7-maven-plugin:2.2:run (default-cli) @ spring-websocket-portfol
io >>>
[INFO]
[INFO] --- maven-resources-plugin:2.5:resources (default-resources) @ spring-web
socket-portfolio ---
[debug] execute contextualize
[INFO] Using 'UTF-8' encoding to copy filtered resources.
[INFO] skip non existing resourceDirectory E:\libraries\spring-websocket-portfol
io\src\main\resources
[INFO]
[INFO] --- maven-compiler-plugin:2.3.2:compile (default-compile) @ spring-websoc
ket-portfolio ---
[INFO] No sources to compile
[INFO]
[INFO] <<< tomcat7-maven-plugin:2.2:run (default-cli) @ spring-websocket-portfol
io <<<
[INFO]
[INFO] --- tomcat7-maven-plugin:2.2:run (default-cli) @ spring-websocket-portfol
io ---
[INFO] Running war on http://localhost:8080/spring-websocket-portfolio
[INFO] Using existing Tomcat server configuration at E:\libraries\spring-websock
et-portfolio\target\tomcat
[INFO] create webapp with contextPath: /spring-websocket-portfolio
Feb 27, 2014 10:20:46 AM org.apache.coyote.AbstractProtocol init
INFO: Initializing ProtocolHandler ["http-bio-8080"]
Feb 27, 2014 10:20:46 AM org.apache.catalina.core.StandardService startInternal
INFO: Starting service Tomcat
Feb 27, 2014 10:20:46 AM org.apache.catalina.core.StandardEngine startInternal
INFO: Starting Servlet Engine: Apache Tomcat/7.0.47
Feb 27, 2014 10:20:49 AM org.apache.catalina.core.ApplicationContext log
INFO: No Spring WebApplicationInitializer types detected on classpath
Feb 27, 2014 10:20:49 AM org.apache.coyote.AbstractProtocol start
INFO: Starting ProtocolHandler ["http-bio-8080"]

Он застрял там и не идет вперед.

4b9b3361

Ответ 1

У меня была та же проблема. Этот поток дал мне достаточно подсказок, чтобы решить проблему. Большое спасибо.

РЕШЕНИЕ: Если у вас есть Spring MVC Dispatcher Servlet, настроенный в вашем web.xml и сопоставленный с шаблоном url, как показано ниже

<servlet-mapping>
    <servlet-name>dispatcher</servlet-name>
    <url-pattern>/webui/*</url-pattern>
</servlet-mapping>

Затем вам нужно создать экземпляр SockJS, как показано ниже.

var socket = new SockJS('/contextPath/webui/hello');

ПРИМЕЧАНИЕ. Замените contextPath контуром контекста вашего приложения.

Ответ 2

Попробуйте добавить папку с ресурсами внутри webapp, где все файлы stomp и sockjs.js становятся доступными. Взгляните на этот пример запущенного приложения, которое можно запустить с помощью mvn clean install jetty:run.

Проблема заключается в том, что либо sockjs не находится на сервере, либо какой-то путь неправильный. На примере, приведенном в ссылке, конечная точка топа может быть настроена следующим образом:

@EnableWebSocketMessageBroker
public class WebSocketConfig extends AbstractWebSocketMessageBrokerConfigurer {
    @Override
    public void registerStompEndpoints(StompEndpointRegistry registry) {
        registry.addEndpoint("/portfolio").withSockJS();
    }

}

Затем в javascript конечную точку можно вызвать так:

 var socket = new SockJS('/spring-websocket-portfolio/portfolio')
 var stompClient = Stomp.over(socket);

где /spring-websocket-portfolio - это корневой путь развертывания вашего приложения.

Ответ 3

Это Расширение Chrome может помочь вам проверить веб-узлы.

Также вы можете посмотреть мой проект simple-chat, в котором используется Spring Загрузка с помощью Websockets.

Ответ 4

Ваше приложение отлично выглядит.

Вы должны обязательно префиксные запросы JavaScript в корневом контексте вашего приложения, как jhadesdev, упомянутые.

Записывает ли ваше приложение дополнительные фильтры или настраивает messageconverters? Возможно, здесь присутствует какой-то другой элемент конфигурации.

Последний пример портфеля должен определенно работать, вот несколько вопросов:

  • Не могли бы вы рассказать нам больше о настройке вашего клиента (браузер, версия)?
  • Поддерживает ли ваш браузер websocket (проверьте его там)?
  • Не могли бы вы также попробовать в режиме инкогнито (возможно, стороннее расширение браузера здесь)?
  • Не могли бы вы проверить, что ваш браузер не использует прокси-сервер HTTP для запросов localhost?
  • Не могли бы вы проверить, находится ли этот HTTP 404 в журнале доступа Tomcat? (и посмотреть, есть ли у вас что-то интересное в тех или в catalina.out?)

Ответ 5

Как отображается ваш DispatcherServlet? Здесь может быть то, что вы ищете

Ответ 6

Я решил эту проблему следующим образом: при создании SockJS добавьте localhost: 8080/вот так

new SockJS('http://localhost:8080/spring-websocket-portfolio/portfolio')

Ответ 7

Для меня решение было включить SockJS в классе WebSocketConfig:

@Override
public void registerStompEndpoints(StompEndpointRegistry registry) {
    registry.addEndpoint("/search")
            .setAllowedOrigins("*")
            .setHandshakeHandler(new DefaultHandshakeHandler())
            .withSockJS();
}