当前位置: 代码迷 >> java >> 从Eclipse调用Rest API时连接超时
  详细解决方案

从Eclipse调用Rest API时连接超时

热度:53   发布时间:2023-08-02 11:11:04.0

帮我! 我有一个Restful API链接,我使用Postman工具调用成功,但是当我在Eclipse上编译一个Restful客户端时,它失败了。 我尝试关闭代理服务器,但未成功。

public class JersyGetClient {

    public static void main(String[] args) {
        String url = "https://abc.custhelp.com/services/rest/connect/v1.4/accounts";
        String name = "thai.hoangan";
        String password = "123456a@";
        String authString = name + ":" + password;
        String authStringEnc = new BASE64Encoder().encode(authString.getBytes());
        System.out.println("Base64 encoded auth string: " + authStringEnc);
        Client restClient = Client.create();
        WebResource webResource = restClient.resource(url);
        ClientResponse resp = webResource.accept("application/json")
                .header("Authorization", "Basic " + authStringEnc)
                .header("OSvC-CREST-Application-Context", "asd")
                .get(ClientResponse.class);
        if (resp.getStatus() != 200) {
            System.err.println("Unable to connect to the server");
        }
        String output = resp.getEntity(String.class);
        System.out.println("response: " + output);
    }
}

输出:

线程“主”中的com.sun.jersey.api.client.ClientHandlerException异常:

java.net.ConnectException:连接超时:在com.sun.jersey.api.client.Client.handle(Client.java)处的com.sun.jersey.client.urlconnection.URLConnectionClientHandler.handle(URLConnectionClientHandler.java:155)处连接:652)com.sun.jersey.api.client.WebResource.handle(WebResource.java:682)com.sun.jersey.api.client.WebResource.access $ 200(WebResource.java:74)在com.sun JersyGetClient.main(JersyGetClient.java:22)的.jersey.api.client.WebResource $ Builder.get(WebResource.java:509)原因:java.net.ConnectException:连接超时:在java.net.DualStackPlainSocketImpl连接java.net.DualStackPlainSocketImpl.socketConnect(DualStackPlainSocketImpl.java:79)上的.connect0(本机方法)java.net.AbstractPlainSocketImpl.java:350处java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350)处的。 )在java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188)在java.net.PlainSocketImpl.connect(PlainSocketIm pl.java:172)位于java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392)在java.net.Socket.connect(Socket.java:589)在sun.security.ssl.SSLSocketImpl.connect(SSLSocketImpl.java :668)在sun.security.ssl.BaseSSLSocketImpl.connect(BaseSSLSocketImpl.java:173)在sun.net.NetworkClient.doConnect(NetworkClient.java:180)在sun.net.www.http.HttpClient.openServer(HttpClient。 java.432)在sun.net.www.http.HttpClient.openServer(HttpClient.java:527)在sun.net.www.protocol.https.HttpsClient。(HttpsClient.java:264)在sun.net.www。 sun.net.www.protocol.https.AbstractDelegateHttpsURLConnection.getNewHttpClient(AbstractDelegateHttpsURLConnection.java:191)上的协议.https.HttpsClient.New(HttpsClient.java:367),sun.net.www.protocol.http.HttpURLConnection.plainConnect0(网址为sun.net.www.protocol.http.HttpURLConnection.java:1105)网址为sun.net.www.protocol.https.AbstractDelegateHttpsURLConnection.connect(AbstractDelegateHttpsURLConnection.java:177)的HttpURLConnection.plainConnect(HttpURLConnection.java:999) 在sun.net.www.protocol.http.HttpURLConnection.getInputStream0(HttpURLConnection.java:1513)在sun.net.www.protocol.http.HttpURLConnection.getInputStream(HttpURLConnection.java:1441)在java.net.HttpURLConnection.getResponseCode (HttpURLConnection.java:480),位于sun.net.www.protocol.https.HttpsURLConnectionImpl.getResponseCode(HttpsURLConnectionImpl.java:338),位于com.sun.jersey.client.urlconnection.URLConnectionClientHandler._invoke(URLConnectionClientHandler.java:253) com.sun.jersey.client.urlconnection.URLConnectionClientHandler.handle(URLConnectionClientHandler.java:153)...还有5个

哦,我解决了,只需添加:

    System.setProperty("https.proxyHost", "proxytest.vcb");
    System.setProperty("https.proxyPort", "8080");
  相关解决方案