19

我在搜索我的网站上有一个自动完成/提前输入功能。我看到有时他们是与之相关的例外。我们正在使用代理服务器。

org.apache.http.conn.HttpHostConnectException: Connection to http://proxy.xyz.com:60 refused    

at org.apache.http.impl.conn.DefaultClientConnectionOperator.openConnection(DefaultClientConnectionOperator.java:159)
at org.apache.http.impl.conn.AbstractPoolEntry.open(AbstractPoolEntry.java:149)
at org.apache.http.impl.conn.AbstractPooledConnAdapter.open(AbstractPooledConnAdapter.java:108)
at org.apache.http.impl.client.DefaultRequestDirector.execute(DefaultRequestDirector.java:415)
at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:641)
at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:576)
at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:554)
at com.xxx.dd.sone.integration.SearchDAO.getJSONData(SearchDAO.java:60)
at com.xxx.dd.sone.integration.SearchDAO.searchAutoCompleteResults(SearchDAO.java:560)
at com.xxx.dd.sone.presentation.util.SearchAutoCompleteUtil.doGet(SearchAutoCompleteUtil.java:26)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:731)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:845)
at weblogic.servlet.internal.StubSecurityHelper$ServletServiceAction.run(StubSecurityHelper.java:242)
at weblogic.servlet.internal.ServletStubImpl.execute(ServletStubImpl.java:352)
at weblogic.servlet.internal.ServletStubImpl.execute(ServletStubImpl.java:236)
at weblogic.servlet.internal.WebAppServletContext$ServletInvocationAction.run(WebAppServletContext.java:3254)
at weblogic.servlet.provider.WlsSubjectHandle.run(WlsSubjectHandle.java:57)
at weblogic.servlet.internal.WebAppServletContext.doSecuredExecute(WebAppServletContext.java:2163)
at weblogic.servlet.internal.WebAppServletContext.execute(WebAppServletContext.java:2074)
at weblogic.servlet.internal.ServletRequestImpl.run(ServletRequestImpl.java:1512)
at weblogic.servlet.provider.ContainerSupportProviderImpl$WlsRequestExecutor.run(ContainerSupportProviderImpl.java:255)
at weblogic.work.ExecuteRequestAdapter.execute(ExecuteRequestAdapter.java:22)
at weblogic.kernel.ExecuteThread.execute(ExecuteThread.java:147)
at weblogic.kernel.ExecuteThread.run(ExecuteThread.java:119)

引起:java.net.ConnectException:连接被拒绝

这是我的编码方式

public HashMap<String, Object> getJSONData(String url)throws Exception {
    DefaultHttpClient httpClient = new DefaultHttpClient();
    HttpParams params = httpClient.getParams();
    try {
        HttpConnectionParams.setConnectionTimeout(params, 10000);
        HttpConnectionParams.setSoTimeout(params, 10000);
    } catch (Exception e) {
        e.printStackTrace();
        throw e;
    }
    HttpHost proxy = new HttpHost(proxy.xyz.com, 60);
    ConnRouteParams.setDefaultProxy(params, proxy);
    URI uri;
    InputStream data = null;
        uri = new URI(url);
        HttpGet method = new HttpGet(uri);
        HttpResponse response=null;
        try {
        response = httpClient.execute(method);
        }catch(Exception e) {
            e.printStackTrace();
            throw e;
        }
        data = response.getEntity().getContent();
    Reader r = new InputStreamReader(data);
    HashMap<String, Object> jsonObj = (HashMap<String, Object>) GenericJSONUtil.fromJson(r);
    return jsonObj;
}

谁能告诉我为什么我只在一段时间内得到这个例外?这是否可能是由于我们的网站不支持从 Android 应用程序发出搜索请求而导致从 Android 应用程序发出搜索请求时引起的

4

3 回答 3

35

当您尝试打开与当前没有任何东西在侦听连接的 IP 地址/端口的 TCP 连接时,会发生“连接被拒绝”错误。如果没有任何东西在监听,服务器端的操作系统会“拒绝”连接。

如果这种情况间歇性发生,那么最可能的解释是(IMO):

  • 您正在与之交谈的服务器(“proxy.xyz.com”/端口 60)正在上升和下降,或者
  • 在您的客户端和代理之间有一些东西1间歇性地向无法运行的主机发送请求或其他东西。

这是否可能是由于我们的网站不支持从 Android 应用程序发出的请求而从 Android 应用程序发出搜索请求时导致此异常。

似乎不太可能。您说“连接被拒绝”异常消息说它是拒绝连接的代理,而不是您的服务器。此外,如果服务器不处理某些类型的请求,它仍然必须接受 TCP 连接以找出请求是什么……然后才能拒绝它。


1 - 例如,它可能是一个将 DNS 名称循环解析为不同 IP 地址的 DNS。或者它可能是一个基于 IP 的负载均衡器。

于 2013-03-21T11:55:16.913 回答
0

就我而言,问题是 HTTP URL 中缺少“s”。错误是:“HttpHostConnectException:连接到 someendpoint.com:80 [someendpoint.com/127.0.0.1] 失败:连接被拒绝”端点和 IP 显然已更改以保护网络。

于 2017-02-02T21:33:22.067 回答
0

有时你必须为 gradle 设置代理服务器,你可以尝试在 .gradle 文件下的 gradle.properties 中更改代理服务器的 ip 地址

于 2020-04-05T15:19:38.680 回答