UnknownHostException:名称或服务未知

时间:2015-10-09 02:17:02

标签: java exception host okhttp

我正在尝试使用com.squareup.okhttp中的OkHttpClient从API返回一些数据。我遇到了一些我最终能够克服的错误,但是我无法通过这个主机异常错误,这里的任何内容似乎都不足以解决我的问题。

下面是我尝试使用它的输出代码,如果有人知道如何克服错误我会很感激。

CODE

public void connect() {         
    OkHttpClient client = new OkHttpClient();

    com.squareup.okhttp.Request request = new com.squareup.okhttp.Request.Builder()
    .url("https://socialweb-analytics.lcloud.com/api/public/reports/jobs?companyKey=ato")
    .get()
    .addHeader("authorization", "Basic c2RidXNpbmVzc2FuYWx5dGljc0BhdG8uZ292LmF1OkFuYWx5dGljezEh")
    .addHeader("cache-control", "no-cache")
    .addHeader("postman-token", "65ef5553-77b5-053f-9c01-4fdf76bdc92f")
    .build();

    System.out.println(request.toString());

    try {
        Response response = client.newCall(request).execute();
        System.out.println(response);
    } catch (IOException e) {
        e.printStackTrace();
    }
}

输出

Request{method=GET, url=https://socialweb-analytics.lcloud.com/api/public/reports/jobs?companyKey=ato, tag=null}
java.net.UnknownHostException: socialweb-analytics.lcloud.com: Name or service not known
    at java.net.Inet6AddressImpl.lookupAllHostAddr(Native Method)
    at java.net.InetAddress$1.lookupAllHostAddr(InetAddress.java:922)
    at java.net.InetAddress.getAddressesFromNameService(InetAddress.java:1314)
    at java.net.InetAddress.getAllByName0(InetAddress.java:1267)
    at java.net.InetAddress.getAllByName(InetAddress.java:1183)
    at java.net.InetAddress.getAllByName(InetAddress.java:1119)
    at com.squareup.okhttp.internal.Network$1.resolveInetAddresses(Network.java:29)
    at com.squareup.okhttp.internal.http.RouteSelector.resetNextInetSocketAddress(RouteSelector.java:187)
    at com.squareup.okhttp.internal.http.RouteSelector.nextProxy(RouteSelector.java:156)
    at com.squareup.okhttp.internal.http.RouteSelector.next(RouteSelector.java:98)
    at com.squareup.okhttp.internal.http.HttpEngine.createNextConnection(HttpEngine.java:344)
    at com.squareup.okhttp.internal.http.HttpEngine.connect(HttpEngine.java:327)
    at com.squareup.okhttp.internal.http.HttpEngine.sendRequest(HttpEngine.java:245)
    at com.squareup.okhttp.Call.getResponse(Call.java:267)
    at com.squareup.okhttp.Call$ApplicationInterceptorChain.proceed(Call.java:224)
    at com.squareup.okhttp.Call.getResponseWithInterceptorChain(Call.java:195)
    at com.squareup.okhttp.Call.execute(Call.java:79)
    at technical_services.persistence.lithium.LithiumDataStore.connect1(LithiumDataStore.java:127)
    at application.lithium_etl.LithiumTestController.main(LithiumTestController.java:24)

3 个答案:

答案 0 :(得分:6)

对于“java.net.UnknownHostException:[hostname]”

这样的错误

原因是你的主机名不在/ etc / hosts中,解决方案很简单:

sudo vim /etc/hosts

更改线条如下:

127.0.0.1  localhost

为:

127.0.0.1  [hostname] localhost

保存并退出。如果问题仍然存在,可能需要重新启动或运行:

sudo ifconfig eth0 down&&sudo ifconfig eth0 up

希望它可以帮到你!

答案 1 :(得分:3)

扩展zhenbo xu&#39答案很好,这就是我在EC2中使用sed自动执行的操作。

sudo sed -i -e '/127.0.0.1/ s/\(localhost\)/'$(hostname)' \1/' /etc/hosts

请注意,要允许变量扩展,单引号会在子shell调用周围结束并重新启动。

hostname是某些Linux系统上的可执行文件(但可能不是全部,因此您可以使用环境变量,或删除子shell周围的引号并使用静态字符串)。

\1sed魔法,它会使"捕获"将转义括号中的搜索字符串(s / search / replacement /)返回到替换字符串中。

答案 2 :(得分:0)

由于您尚未发布您connect()调用的代码,因此请参阅我的以下工作代码

    private class StringRequest extends AsyncTask<Void, Void, String> {
        @Override
        protected String doInBackground(Void... voids) {
            OkHttpClient client = new OkHttpClient();
            Request request = new Request.Builder()
                    .url("https://socialweb-analytics.lcloud.com/api/public/reports/jobs?companyKey=ato")
                    .addHeader("authorization", "Basic c2RidXNpbmVzc2FuYWx5dGljc0BhdG8uZ292LmF1OkFuYWx5dGljezEh")
                    .addHeader("cache-control", "no-cache")
                    .addHeader("postman-token", "65ef5553-77b5-053f-9c01-4fdf76bdc92f")
                    .build();
            try {
                Response response = client.newCall(request).execute();
                return response.body().string();
            } catch (IOException e) {
                e.printStackTrace();
            }
            return null;
        }
        @Override
        protected void onPostExecute(String s) {
            super.onPostExecute(s);
            System.out.println(s);
        }
    }

然后在onCreate:

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    mTextView = (TextView) findViewById(R.id.textView);
    new StringRequest().execute();
}

我的应用运行并获得以下结果(可能是因为过期/无效令牌):

I/System.out: {"code":500,"message":"There was an error processing your request. It has been logged (ID a2f28b587b2f9dcc)."}

P / S:确保您在<uses-permission android:name="android.permission.INTERNET" />文件

中设置了AndroidManifest.xml