简体   繁体   English

发起WebSocket连接的HTTP请求失败

[英]The HTTP request to initiate the WebSocket connection failed

I want to send a message to websocket from java code.我想从java代码向 websocket 发送消息。

This is configuration class for websockets这是websockets配置类

@Configuration
@EnableWebSocket
public class WebSocketConfig implements WebSocketConfigurer {
    private WebSocketHandler handler;

    public WebSocketConfig(WebSocketHandler handler) {
        this.handler = handler;
    }

    @Override
    public void registerWebSocketHandlers(WebSocketHandlerRegistry webSocketHandlerRegistry) {
        webSocketHandlerRegistry.addHandler(this.handler, "/ws");
    }
}

This is websocket handler这是websocket处理程序

@Component
public class WebSocketHandler extends TextWebSocketHandler {
    private static final Logger LOGGER = JavaLogUtils.getLogger();

    @Override
    public void afterConnectionEstablished(WebSocketSession session) throws Exception {
        super.afterConnectionEstablished(session);
    }

    @Override
    protected void handleTextMessage(WebSocketSession session, TextMessage message) throws Exception {
        LOGGER.info(" Server >>>> {}", message);
        session.sendMessage(message);
    }
}

When I send message from html page via javascript like this当我像这样通过javascripthtml页面发送消息时

$(function(){

    var connection = new WebSocket('ws://localhost:8080/ws');
    connection.onopen = function () {
        console.log('Connected...');
    };
    connection.onmessage = function(event){
        console.log('>>>>> ' + event.data);
        var json = JSON.parse(event.data);
        $("#output").append("<span><strong>" + json.user + "</strong>: <em>" + json.message  +"</em></span><br/>");
    };
    connection.onclose   = function(event){
        $("#output").append("<p class=\"text-uppercase\"><strong>CONNECTION: CLOSED</strong></p>");
    };

    $("#send").click(function(){
        var message = {}
        message["user"] = $("#user").val();
        message["message"] = $("#message").val();
        connection.send(JSON.stringify(message));
    });

});

It works fine.它工作正常。 But when I try to send the message from java client it fails但是当我尝试从java client发送消息时它失败了

@SpringBootApplication
@ComponentScan("com.lapots.breed.platform.cloud.boot")
@EnableJpaRepositories("com.lapots.breed.platform.cloud.boot.repository")
@EntityScan("com.lapots.breed.platform.cloud.boot.domain")
@EnableAspectJAutoProxy
@EnableJms
public class JavaCloudSampleApplication {

    public static void main(String[] args) {
        SpringApplication.run(JavaCloudSampleApplication.class, args);
    }

    @Bean
    public CommandLineRunner welcomeSocketMessage(WebSocketHandler handler) throws URISyntaxException {
        return args -> {
            StandardWebSocketClient client = new StandardWebSocketClient();
            ListenableFuture<WebSocketSession> future = client.doHandshake(handler,
                    new WebSocketHttpHeaders(),
                    new URI("ws://localhost:8080/ws"));
            WebSocketSession session = future.get();
            WebSocketMessage<String> message = new TextMessage("Hello from Spring");
            session.sendMessage(message);
        };
    }
}

and I get this error我收到这个错误

java.lang.IllegalStateException: Failed to load ApplicationContext
        at org.springframework.test.context.cache.DefaultCacheAwareContextLoaderDelegate.loadContext(DefaultCacheAwareContextLoaderDelegate.java:124) ~[spring-test-4.3.10.RELEASE.jar:4.3.10.RELEASE]
        at org.springframework.test.context.support.DefaultTestContext.getApplicationContext(DefaultTestContext.java:83) ~[spring-test-4.3.10.RELEASE.jar:4.3.10.RELEASE]
        at org.springframework.test.context.web.ServletTestExecutionListener.setUpRequestContextIfNecessary(ServletTestExecutionListener.java:189) ~[spring-test-4.3.10.RELEASE.jar:4.3.10.RELEASE]
        at org.springframework.test.context.web.ServletTestExecutionListener.prepareTestInstance(ServletTestExecutionListener.java:131) ~[spring-test-4.3.10.RELEASE.jar:4.3.10.RELEASE]
        at org.springframework.test.context.TestContextManager.prepareTestInstance(TestContextManager.java:230) ~[spring-test-4.3.10.RELEASE.jar:4.3.10.RELEASE]
        at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.createTest(SpringJUnit4ClassRunner.java:228) [spring-test-4.3.10.RELEASE.jar:4.3.10.RELEASE]
        at org.springframework.test.context.junit4.SpringJUnit4ClassRunner$1.runReflectiveCall(SpringJUnit4ClassRunner.java:287) [spring-test-4.3.10.RELEASE.jar:4.3.10.RELEASE]
        at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12) [junit-4.12.jar:4.12]
        at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.methodBlock(SpringJUnit4ClassRunner.java:289) [spring-test-4.3.10.RELEASE.jar:4.3.10.RELEASE]
        at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.runChild(SpringJUnit4ClassRunner.java:247) [spring-test-4.3.10.RELEASE.jar:4.3.10.RELEASE]
        at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.runChild(SpringJUnit4ClassRunner.java:94) [spring-test-4.3.10.RELEASE.jar:4.3.10.RELEASE]
        at org.junit.runners.ParentRunner$3.run(ParentRunner.java:290) [junit-4.12.jar:4.12]
        at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:71) [junit-4.12.jar:4.12]
        at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:288) [junit-4.12.jar:4.12]
        at org.junit.runners.ParentRunner.access$000(ParentRunner.java:58) [junit-4.12.jar:4.12]
        at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:268) [junit-4.12.jar:4.12]
        at org.springframework.test.context.junit4.statements.RunBeforeTestClassCallbacks.evaluate(RunBeforeTestClassCallbacks.java:61) [spring-test-4.3.10.RELEASE.jar:4.3.10.RELEASE]
        at org.springframework.test.context.junit4.statements.RunAfterTestClassCallbacks.evaluate(RunAfterTestClassCallbacks.java:70) [spring-test-4.3.10.RELEASE.jar:4.3.10.RELEASE]
        at org.junit.runners.ParentRunner.run(ParentRunner.java:363) [junit-4.12.jar:4.12]
        at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.run(SpringJUnit4ClassRunner.java:191) [spring-test-4.3.10.RELEASE.jar:4.3.10.RELEASE]
        at org.apache.maven.surefire.junit4.JUnit4Provider.execute(JUnit4Provider.java:365) [surefire-junit4-2.20.jar:2.20]
        at org.apache.maven.surefire.junit4.JUnit4Provider.executeWithRerun(JUnit4Provider.java:272) [surefire-junit4-2.20.jar:2.20]
        at org.apache.maven.surefire.junit4.JUnit4Provider.executeTestSet(JUnit4Provider.java:236) [surefire-junit4-2.20.jar:2.20]
        at org.apache.maven.surefire.junit4.JUnit4Provider.invoke(JUnit4Provider.java:159) [surefire-junit4-2.20.jar:2.20]
        at org.apache.maven.surefire.booter.ForkedBooter.invokeProviderInSameClassLoader(ForkedBooter.java:386) [surefire-booter-2.20.jar:2.20]
        at org.apache.maven.surefire.booter.ForkedBooter.runSuitesInProcess(ForkedBooter.java:323) [surefire-booter-2.20.jar:2.20]
        at org.apache.maven.surefire.booter.ForkedBooter.main(ForkedBooter.java:143) [surefire-booter-2.20.jar:2.20]
Caused by: java.lang.IllegalStateException: Failed to execute CommandLineRunner
        at org.springframework.boot.SpringApplication.callRunner(SpringApplication.java:735) ~[spring-boot-1.5.6.RELEASE.jar:1.5.6.RELEASE]
        at org.springframework.boot.SpringApplication.callRunners(SpringApplication.java:716) ~[spring-boot-1.5.6.RELEASE.jar:1.5.6.RELEASE]
        at org.springframework.boot.SpringApplication.afterRefresh(SpringApplication.java:703) ~[spring-boot-1.5.6.RELEASE.jar:1.5.6.RELEASE]
        at org.springframework.boot.SpringApplication.run(SpringApplication.java:304) ~[spring-boot-1.5.6.RELEASE.jar:1.5.6.RELEASE]
        at org.springframework.boot.test.context.SpringBootContextLoader.loadContext(SpringBootContextLoader.java:120) ~[spring-boot-test-1.5.6.RELEASE.jar:1.5.6.RELEASE]
        at org.springframework.test.context.cache.DefaultCacheAwareContextLoaderDelegate.loadContextInternal(DefaultCacheAwareContextLoaderDelegate.java:98) ~[spring-test-4.3.10.RELEASE.jar:4.3.10.RELEASE]
        at org.springframework.test.context.cache.DefaultCacheAwareContextLoaderDelegate.loadContext(DefaultCacheAwareContextLoaderDelegate.java:116) ~[spring-test-4.3.10.RELEASE.jar:4.3.10.RELEASE]
        ... 26 common frames omitted
Caused by: java.util.concurrent.ExecutionException: javax.websocket.DeploymentException: The HTTP request to initiate the WebSocket connection failed
        at java.util.concurrent.FutureTask.report(FutureTask.java:122) ~[na:1.8.0_121]
        at java.util.concurrent.FutureTask.get(FutureTask.java:192) ~[na:1.8.0_121]
        at com.lapots.breed.platform.cloud.boot.JavaCloudSampleApplication.lambda$welcomeSocketMessage$4(JavaCloudSampleApplication.java:76) ~[classes/:na]
        at org.springframework.boot.SpringApplication.callRunner(SpringApplication.java:732) ~[spring-boot-1.5.6.RELEASE.jar:1.5.6.RELEASE]
        ... 32 common frames omitted
Caused by: javax.websocket.DeploymentException: The HTTP request to initiate the WebSocket connection failed
        at org.apache.tomcat.websocket.WsWebSocketContainer.connectToServer(WsWebSocketContainer.java:395) ~[tomcat-embed-websocket-8.5.16.jar:8.5.16]
        at org.springframework.web.socket.client.standard.StandardWebSocketClient$1.call(StandardWebSocketClient.java:150) ~[spring-websocket-4.3.10.RELEASE.jar:4.3.10.RELEASE]
        at org.springframework.web.socket.client.standard.StandardWebSocketClient$1.call(StandardWebSocketClient.java:147) ~[spring-websocket-4.3.10.RELEASE.jar:4.3.10.RELEASE]
        at java.util.concurrent.FutureTask.run(FutureTask.java:266) ~[na:1.8.0_121]
        at java.lang.Thread.run(Thread.java:745) ~[na:1.8.0_121]
Caused by: java.util.concurrent.ExecutionException: java.io.IOException: The remote computer refused the network connection.

        at sun.nio.ch.PendingFuture.get(PendingFuture.java:202) ~[na:1.8.0_121]
        at org.apache.tomcat.websocket.WsWebSocketContainer.connectToServer(WsWebSocketContainer.java:336) ~[tomcat-embed-websocket-8.5.16.jar:8.5.16]
        ... 4 common frames omitted
Caused by: java.io.IOException: The remote computer refused the network connection.

        at sun.nio.ch.Iocp.translateErrorToIOException(Iocp.java:309) ~[na:1.8.0_121]
        at sun.nio.ch.Iocp.access$700(Iocp.java:46) ~[na:1.8.0_121]
        at sun.nio.ch.Iocp$EventHandlerTask.run(Iocp.java:399) ~[na:1.8.0_121]
        ... 1 common frames omitted

[ERROR] Tests run: 1, Failures: 0, Errors: 1, Skipped: 0, Time elapsed: 8.071 s <<< FAILURE! - in com.lapots.breed.platform.cloud.boot.app.JavaCloudSampleApplicationTests
[ERROR] contextLoads(com.lapots.breed.platform.cloud.boot.app.JavaCloudSampleApplicationTests)  Time elapsed: 0 s  <<< ERROR!
java.lang.IllegalStateException: Failed to load ApplicationContext
Caused by: java.lang.IllegalStateException: Failed to execute CommandLineRunner
Caused by: java.util.concurrent.ExecutionException: javax.websocket.DeploymentException: The HTTP request to initiate the WebSocket connection failed
Caused by: javax.websocket.DeploymentException: The HTTP request to initiate the WebSocket connection failed
Caused by: java.util.concurrent.ExecutionException:
java.io.IOException: The remote computer refused the network connection.

Caused by: java.io.IOException:
The remote computer refused the network connection.
@Override
public void afterConnectionEstablished(WebSocketSession session) throws Exception {
    TimeUnit.SECONDS.sleep(1);
}

I have running 100 users with 10 threads.我有 100 个用户运行 10 个线程。

I simply sleep for a sec after connection has been established that solved my issue.建立连接后,我只是睡了一会儿,解决了我的问题。

This appears to be a network-related problem:这似乎是一个与网络相关的问题:

java.io.IOException: The remote computer refused the network connection.

Likely a firewall or other network infrastructure preventing the connection.可能是防火墙或其他网络基础设施阻止了连接。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

相关问题 WebSocket DeploymentException 连接失败 - WebSocket DeploymentException connection failed WebSocket 连接到“ws://localhost:8081/.../.../...”失败:HTTP 身份验证失败; 没有可用的有效凭据 - WebSocket connection to 'ws://localhost:8081/.../.../...' failed: HTTP Authentication failed; no valid credentials available 程序尝试启动与Google的连接时的HTTP响应403? - HTTP response 403 when program tries to initiate connection to Google? 无法执行 HTTP 请求:连接到 localhost:8000 [localhost/127.0.0.1] 失败:连接被拒绝(连接被拒绝) - Unable to execute HTTP request: Connect to localhost:8000 [localhost/127.0.0.1] failed: Connection refused (Connection refused) Android Websocket 连接失败(Galaxy s4) - Android Websocket connection failed (Galaxy s4) 开启 Spring Security 时创建 WebSocket 连接失败 - Failed to create WebSocket connection when Spring Security is on OrientDB http请求失败…? - OrientDB http request failed…? 假设已经存在http2连接,是否可以从Jetty启动http2会话或流? - Is it possible to initiate http2 session or stream from Jetty Assuming a http2 connection already exists? 在Akka HTTP中保持WebSocket连接存活的最佳方法? - Best way to keep WebSocket connection alive in Akka HTTP? 使用Maven,WebSocket连接失败:WebSocket握手期间出错:意外响应代码:404 - Using Maven, WebSocket connection to failed: Error during WebSocket handshake: Unexpected response code: 404
 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM