Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/spring/11.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java SpringMVC+;Websocket+;聊天室初始HttpHandshake失败_Java_Spring_Spring Mvc_Websocket_Spring Websocket - Fatal编程技术网

Java SpringMVC+;Websocket+;聊天室初始HttpHandshake失败

Java SpringMVC+;Websocket+;聊天室初始HttpHandshake失败,java,spring,spring-mvc,websocket,spring-websocket,Java,Spring,Spring Mvc,Websocket,Spring Websocket,我正在尝试在我现有的Spring MVC应用程序中实现聊天。我指的是github的以下两个链接- 但当我尝试通过websocket连接时,最初的HttpHandhsake似乎失败了。 下面是关于源代码的简介。 配置类是- 鼻腔结构 ConChactWebSocketConfig 只有ChatController处理WebSocket&webapp/WEB-INF/pages/home.jsp包含客户端js 因此,请看一下代码并向我建议如何更改以使聊天正常工作。目前,当我在网络选项卡上看到时,

我正在尝试在我现有的Spring MVC应用程序中实现聊天。我指的是github的以下两个链接-

  • 但当我尝试通过websocket连接时,最初的HttpHandhsake似乎失败了。 下面是关于源代码的简介。 配置类是-

  • 鼻腔结构
  • ConChactWebSocketConfig
  • 只有ChatController处理WebSocket&webapp/WEB-INF/pages/home.jsp包含客户端js

    因此,请看一下代码并向我建议如何更改以使聊天正常工作。目前,当我在网络选项卡上看到时,初始HttpHandshake似乎失败了,因为交换协议请求的延迟非常高(它永远不会返回)

    编辑 网络和控制台面板的屏幕截图-

    您链接的代码相当大,因此很难将所有事情发生的地方隔离开来。。。但当我使用Spring开发WebSocket时,我必须处理以下几件事:

    (作为旁注,我最初遇到了一个与您类似的问题,即初始握手会失败,并显示各种错误消息)

    确保您使用的是最新的Spring 4 这些是我正在使用的特定spring依赖项。从您的pom来看,这里看起来不错,但我将它们包括在列表中以供参考(这些是Gradle依赖声明)

    确保您使用的是servlet 3.0规范 xml应该将servlet规范版本声明为3.0,而不是2.3。看起来您正在使用2.3

    <web-app version="3.0" xmlns="http://java.sun.com/xml/ns/javaee"
        xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
        xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
        http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd">
    
    正确设置客户端内容 我使用的是AngularJS,所以这些东西在消息服务中

    var socket = new SockJS('https://localhost:8443/WildFire/endpoint');
    var stompClient  = Stomp.over(socket);
    
    stompClient.connect('empty', 'empty', function(frame){
        $log.info("Connected");
        stompClient.subscribe('/user/topic/notifications', function(message){
            addMessage(JSON.parse(message.body));
        });
    });
    
    我需要引用websocket的完整URL,因为SockJS没有使用到端点的相对路径。在我做出改变之前,它一直在导致奇怪的错误。我正在进行特定于用户的主题订阅,因此在订阅声明中使用“/user/…”

    此外,我必须为初始的stompClient连接提供虚拟凭据(例如“empty/empty”),否则我将得到缺少凭据的错误。我认为使用空字符串('','')也可以

    设置spring安全性 在您的安全设置中,您的“/chat”URL似乎处于“完全许可”状态。这不应该引起问题,但您可以像保护任何其他URL一样保护websocket端点,因为它都是作为Spring处理的基本servlet请求启动的

    我的安全配置将websocket端点处理为需要经过身份验证的会话和HTTPS,这在websocket和消息传递系统中运行良好。由于websocket连接是以servlet请求启动的,因此使用初始登录期间建立的JSESSIONID对其进行身份验证,与其他任何连接一样


    无论如何,我不确定是什么导致了你的具体问题,但这是我让我的应用程序工作的过程。看起来你所做的事情与我所做的非常相似,所以希望这能帮助你找出问题所在。

    谢谢你,伙计。这是一个非常好的答案,值得投票。我尝试了你提出的所有建议,但没有成功。我将用截图编辑我的问题,请看一看,以获得更好的想法。此外,我将尝试创建新的MVC项目,我刚开始想,也许我现有的网络配置在配置WebSocketConfiguration时产生了问题。如果您查看网络面板,交换协议请求仍处于挂起状态。它会后退并开始尝试其他协议,如xhr_streaming和xhr,但它们也会失败。
    <async-supported>true</async-supported>
    
    <websocket:message-broker application-destination-prefix="/rt">
        <websocket:stomp-endpoint path="/endpoint" >
            <websocket:sockjs />
        </websocket:stomp-endpoint>
        <websocket:simple-broker prefix="/topic" />
    </websocket:message-broker>
    
    SimpMessagingTemplate simpMessagingtemplate;
    @Autowired
    public void setSimpMessagingTemplate(SimpMessagingTemplate template){
        simpMessagingtemplate = template;
    }
    
    @Override
    public void sendMessage(UserDetails userDetails, String message, DateTime time) {
        // Send notifications based on subscriptions
        for(String destUser : ...list of users...){
            this.simpMessagingtemplate.convertAndSendToUser(
                destUser,
                "/topic/notifications", 
                new MessagePayload(... Your stuff here...));
        }
    }
    
    var socket = new SockJS('https://localhost:8443/WildFire/endpoint');
    var stompClient  = Stomp.over(socket);
    
    stompClient.connect('empty', 'empty', function(frame){
        $log.info("Connected");
        stompClient.subscribe('/user/topic/notifications', function(message){
            addMessage(JSON.parse(message.body));
        });
    });