SockJS无法创建/连接到Spring WebSocket

时间:2017-06-17 22:18:40

标签: spring spring-mvc stomp spring-websocket sockjs

我正在学习Spring WebSocket。我已经成功运行了这个Spring WebSocket教程。现在我试图在我现有的Spring MVC应用程序中将 as-is 合并。当我从Chrome浏览器运行它时,我在其开发控制台中看到以下错误。

Chrome控制台

Opening Web Socket...
GET http://localhost:8080/MyAppName/api/gs-guide-websocket/info?t=1497735312528 500 (Internal Server Error) -- abstract-xhr.js:132
Whoops! Lost connection to http://localhost:8080/MyAppName/api/gs-guide-websocket -- stomp.min.js:8 

服务器端错误

javax.servlet.ServletException: Could not resolve view with name '/MyAppName/api/gs-guide-websocket/info' in servlet with name 'MyAppName'
at org.springframework.web.servlet.DispatcherServlet.render(DispatcherServlet.java:1262)
at org.springframework.web.servlet.DispatcherServlet.processDispatchResult(DispatcherServlet.java:1037)

客户端

function connect() {
    var socket = new SockJS('/MyAppName/api/gs-guide-websocket');
    stompClient = Stomp.over(socket);
    stompClient.connect({}, function (frame) {
        setConnected(true);
        console.log('Connected: ' + frame);
        stompClient.subscribe('/topic/greetings', function (greeting) {
            showGreeting(JSON.parse(greeting.body).content);
        });
    });
}

服务器端

@Configuration
@EnableWebSocketMessageBroker
public class WebSocketConfig extends AbstractWebSocketMessageBrokerConfigurer {

    @Override
    public void configureMessageBroker(MessageBrokerRegistry config) {
        config.enableSimpleBroker("/topic");
        config.setApplicationDestinationPrefixes("/app");
    }

    @Override
    public void registerStompEndpoints(StompEndpointRegistry registry) {
        registry.addEndpoint("/MyAppName/api/gs-guide-websocket").withSockJS();
    }

}

我已经尝试解决这个问题几个小时了。我该如何解决这个问题?

TY

2 个答案:

答案 0 :(得分:0)

如果您的应用程序上下文为MyAppName,那么您不需要在addEndpoint方法中指定它 - 此路径与您的应用程序上下文相关。

可能registry.addEndpoint("/MyAppName/api/gs-guide-websocket")使用路径/MyAppName/MyAppName/api/gs-guide-websocket

注册端点

答案 1 :(得分:0)

也许,我的示例将提示问题

我的应用程序基本URL http:// localhost:8080 / socket /

我的js文件

function connect() {
    var socket = new SockJS('/socket/greeting');
    stompClient = Stomp.over(socket);

    stompClient.connect({name: 'test'}, function(frame) {
        
        console.log("session Id:" + socket._transport.url); 
        console.log("user Id:" + socket.current_user_id);
        console.log("socket Id:" + stompClient.id);
        var sessionId = /\/([^\/]+)\/websocket/.exec(socket._transport.url)[1];
        $("#fname").val(sessionId);
        console.log("socket Id:" + sessionId);
        stompClient.subscribe("/user/queue/errors", function(message) {
            alert("Error " + message.body);
        });

        stompClient.subscribe("/user/queue/reply", function(message) {
            showGreeting(message.body);
        });
    }, function(error) {
        alert("STOMP error " + error);
    });
}

我的套接字配置

package com.connectips.socket.config;

import org.springframework.context.annotation.Configuration;
import org.springframework.messaging.simp.config.MessageBrokerRegistry;
import org.springframework.web.socket.config.annotation.EnableWebSocketMessageBroker;
import org.springframework.web.socket.config.annotation.StompEndpointRegistry;
import org.springframework.web.socket.config.annotation.WebSocketMessageBrokerConfigurer;

import com.connectips.socket.interceptor.HttpHandshakeInterceptor;

@Configuration
@EnableWebSocketMessageBroker
public class SocketConfig implements WebSocketMessageBrokerConfigurer{

    @Override
    public void configureMessageBroker(MessageBrokerRegistry config) {
        config.enableSimpleBroker("/topic/", "/queue/");
        config.setApplicationDestinationPrefixes("/app");
    }

    @Override
    public void registerStompEndpoints(StompEndpointRegistry registry) {
        registry.addEndpoint("/greeting").addInterceptors(new HttpHandshakeInterceptor()).withSockJS();
    }
}