Spring RestTemplate 连接重置

12

我想使用Spring工具来消费REST服务,遵循this指南,但我遇到了连接问题。 我想使用GET方法访问REST服务。

http://date.jsontest.com/

我编写了这段代码来消费该服务。

package pack;
import static org.junit.Assert.assertTrue;

import java.util.HashMap;
import java.util.Map;

import javax.annotation.Generated;

import org.junit.Test;
import org.springframework.web.client.RestTemplate;

import com.fasterxml.jackson.annotation.JsonAnyGetter;
import com.fasterxml.jackson.annotation.JsonAnySetter;
import com.fasterxml.jackson.annotation.JsonInclude;
import com.fasterxml.jackson.annotation.JsonProperty;
import com.fasterxml.jackson.annotation.JsonPropertyOrder;


public class RestUtilityTest {

    @JsonInclude(JsonInclude.Include.NON_NULL)
    @JsonPropertyOrder({
        "time",
        "milliseconds_since_epoch",
        "date"
    })
    public class DateTime {

        @JsonProperty("time")
        private String time;
        @JsonProperty("milliseconds_since_epoch")
        private Integer milliseconds_since_epoch;
        @JsonProperty("date")
        private String date;
        private Map<String, Object> additionalProperties = new HashMap<String, Object>();

        @JsonProperty("time")
        public String getTime() {
            return time;
        }

        @JsonProperty("time")
        public void setTime(String time) {
            this.time = time;
        }

        @JsonProperty("milliseconds_since_epoch")
        public Integer getMilliseconds_since_epoch() {
            return milliseconds_since_epoch;
        }

        @JsonProperty("milliseconds_since_epoch")
        public void setMilliseconds_since_epoch(Integer milliseconds_since_epoch) {
            this.milliseconds_since_epoch = milliseconds_since_epoch;
        }

        @JsonProperty("date")
        public String getDate() {
            return date;
        }

        @JsonProperty("date")
        public void setDate(String date) {
            this.date = date;
        }

        @JsonAnyGetter
        public Map<String, Object> getAdditionalProperties() {
            return this.additionalProperties;
        }

        @JsonAnySetter
        public void setAdditionalProperty(String name, Object value) {
            this.additionalProperties.put(name, value);
        }

    }

    @Test
    public void getTest()
    {

        RestTemplate restTemplate = new RestTemplate();
        DateTime datetime = restTemplate.getForObject("http://date.jsontest.com", DateTime.class);

        assertTrue(datetime != null);

    }

}

应用程序抛出以下异常堆栈。
org.springframework.web.client.ResourceAccessException: I/O error on GET request for "http://date.jsontest.com": Connection reset; nested exception is java.net.SocketException: Connection reset
    at org.springframework.web.client.RestTemplate.doExecute(RestTemplate.java:524)
    at org.springframework.web.client.RestTemplate.execute(RestTemplate.java:472)
    at org.springframework.web.client.RestTemplate.getForObject(RestTemplate.java:237)
    at pack.RestUtilityTest.getTest(RestUtilityTest.java:95)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
    at java.lang.reflect.Method.invoke(Unknown Source)
    at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:47)
    at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12)
    at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:44)
    at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17)
    at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:271)
    at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:70)
    at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:50)
    at org.junit.runners.ParentRunner$3.run(ParentRunner.java:238)
    at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:63)
    at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:236)
    at org.junit.runners.ParentRunner.access$000(ParentRunner.java:53)
    at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:229)
    at org.junit.runners.ParentRunner.run(ParentRunner.java:309)
    at org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:50)
    at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:467)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:683)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:390)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:197)
Caused by: java.net.SocketException: Connection reset
    at java.net.SocketInputStream.read(Unknown Source)
    at java.net.SocketInputStream.read(Unknown Source)
    at java.io.BufferedInputStream.fill(Unknown Source)
    at java.io.BufferedInputStream.read1(Unknown Source)
    at java.io.BufferedInputStream.read(Unknown Source)
    at sun.net.www.http.HttpClient.parseHTTPHeader(Unknown Source)
    at sun.net.www.http.HttpClient.parseHTTP(Unknown Source)
    at sun.net.www.http.HttpClient.parseHTTP(Unknown Source)
    at sun.net.www.protocol.http.HttpURLConnection.getInputStream(Unknown Source)
    at java.net.HttpURLConnection.getResponseCode(Unknown Source)
    at org.springframework.http.client.SimpleClientHttpResponse.getRawStatusCode(SimpleClientHttpResponse.java:47)
    at org.springframework.http.client.AbstractClientHttpResponse.getStatusCode(AbstractClientHttpResponse.java:32)
    at org.springframework.web.client.DefaultResponseErrorHandler.getHttpStatusCode(DefaultResponseErrorHandler.java:55)
    at org.springframework.web.client.DefaultResponseErrorHandler.hasError(DefaultResponseErrorHandler.java:49)
    at org.springframework.web.client.RestTemplate.doExecute(RestTemplate.java:510)
    ... 26 more

我尝试了两个不同的网络连接来进行REST调用,所以这不是一个网络连接问题;此外,如果我从浏览器中访问该服务,我可以正确地获得响应。

可能是什么问题呢?

提前感谢您。


你是否已经添加了Jackson库?尝试提取数据时似乎出现了问题,因为URL正常工作。 - Koitoer
嗨@Koitoer,感谢您的回复。我已经将jackson-core、jackson-annotations和jackson-databind(版本2.2.3)依赖项添加到我的pom.xml文件中。 - gvdm
这解决了问题吗?还是要持续下去? - Koitoer
不,问题仍然存在。 - gvdm
1个回答

7

问题已解决。问题与网络连接有关。我所在的网络被防火墙和代理限制了。 现在我正在努力理解如何在被防火墙限制的网络(这是我的公司网络)中完成任务。


我遇到了类似的错误。服务器上是“ClientAbortException”,而客户端上是“SocketException”。您能告诉我在防火墙中需要更改什么以消除此错误吗? - Pytry
1
嗨@Pytry。我现在不在同一家公司,使用其他技术工作,所以暂时无法重现问题并告诉您解决方案:/但是通常情况下,如果您的网络是代理的,则必须在REST客户端中配置公司代理,以便让它通过代理服务器执行请求。 - gvdm

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接