HttpResponse с использованием проблемы с Android: выполнение всегда вызывает исключение?

Я работаю над Android-проектом, и я нахожусь в точке, где я хочу запросить информацию у какого-нибудь API.Похоже, это должно быть очень просто!

Вот общая суть моего кода:

private InputStream retrieveStream2(String url)
{
    DefaultHttpClient client = new DefaultHttpClient();

    HttpGet getRequest = new HttpGet(url);
    System.out.println("getRequest == " + getRequest);
    try {


        HttpResponse getResponse = client.execute(getRequest);//here is teh problem
        final int statusCode = getResponse.getStatusLine().getStatusCode();


        if (statusCode != HttpStatus.SC_OK)
        {
            Log.w(getClass().getSimpleName(),
                    "Error " + statusCode + " for URL " + url);
            return null;
        }

        HttpEntity getResponseEntity = getResponse.getEntity();
        return getResponseEntity.getContent();

    }
    catch (Exception e)
    {
        getRequest.abort();
        Log.w(getClass().getSimpleName(), "Error for URL, YO " + url, e);
    }
    return null;
}

где переменная url - это строка "http://search.twitter.com/search.json?q=javacodegeeks".

Как видите, на этом сайте есть неплохая информация в формате JSON; Моя проблема в том, что каждый раз, когда вызывается client.execute (getRequest);, программа выдает и перехватывает исключение. Не полезно!

Я слышал две вещи:

1) Вы должны установить разрешение для эмулятора / устройства на использование Интернета! - Я думаю, что накрыл это, но, может быть, я сделал это неправильно! В androidmanifest.xml я добавил

< uses-permission android:name="android.permission.INTERNET" >< /uses-permission>

Вот и все.

2) (в чем я не уверен) вы не можете запустить «сетевой» поток внутри потока «ui». Я не совсем уверен, что это означает, но я пошел дальше и последовал некоторому руководству по потокам, обработчикам и AsyncTasks Android. Здесь: Пожалуйста, ознакомьтесь с кодом в учебнике AsyncTask, которому я следовал:

http://www.vogella.de/articles/AndroidPerformance/article.html

Проследив вместе с учебником AsyncTask, я обнаружил, что У меня все еще была та же проблема -

строка: HttpGet httpGet = новый HttpGet (URL) всегда генерировал исключение, как и раньше.

Вот логарифм моей попытки с помощью приведенного выше руководства по потокам:

02-27 20:43:28.565: I/ActivityManager(92): START {cmp=com.Prometheus.R1/.JsonParsingActivity} from pid 574
02-27 20:43:28.565: W/WindowManager(92): Failure taking screenshot for (180x300) to layer 21010
02-27 20:43:28.896: I/System.out(574): pre execute
02-27 20:43:29.236: I/ActivityManager(92): Displayed com.Prometheus.R1/.JsonParsingActivity: +638ms
02-27 20:43:29.329: I/ARMAssembler(35): generated scanline__00000077:03010104_00008001_00000000 [ 89 ipp] (110 ins) at [0x40fad6a8:0x40fad860] in 7204915 ns
02-27 20:43:30.016: W/System.err(574): java.net.UnknownHostException: Unable to resolve host "search.twitter.com": No address associated with hostname
02-27 20:43:30.016: W/System.err(574):  at java.net.InetAddress.lookupHostByName(InetAddress.java:426)
02-27 20:43:30.026: W/System.err(574):  at java.net.InetAddress.getAllByNameImpl(InetAddress.java:242)
02-27 20:43:30.026: W/System.err(574):  at java.net.InetAddress.getAllByName(InetAddress.java:220)
02-27 20:43:30.026: W/System.err(574):  at org.apache.http.impl.conn.DefaultClientConnectionOperator.openConnection(DefaultClientConnectionOperator.java:137)
02-27 20:43:30.036: W/System.err(574):  at org.apache.http.impl.conn.AbstractPoolEntry.open(AbstractPoolEntry.java:164)
02-27 20:43:30.036: W/System.err(574):  at org.apache.http.impl.conn.AbstractPooledConnAdapter.open(AbstractPooledConnAdapter.java:119)
02-27 20:43:30.046: W/System.err(574):  at org.apache.http.impl.client.DefaultRequestDirector.execute(DefaultRequestDirector.java:360)
02-27 20:43:30.046: W/System.err(574):  at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:555)
02-27 20:43:30.046: W/System.err(574):  at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:487)
02-27 20:43:30.055: W/System.err(574):  at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:465)
02-27 20:43:30.055: W/System.err(574):  at com.Prometheus.R1.JsonParsingActivity$DownloadWebPageTask.doInBackground(JsonParsingActivity.java:88)
02-27 20:43:30.055: W/System.err(574):  at com.Prometheus.R1.JsonParsingActivity$DownloadWebPageTask.doInBackground(JsonParsingActivity.java:1)
02-27 20:43:30.055: W/System.err(574):  at android.os.AsyncTask$2.call(AsyncTask.java:264)
02-27 20:43:30.066: W/System.err(574): at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:305) 02-27 20:43:30.066: W/System.err(574): at java.util.concurrent.FutureTask.run(FutureTask.java:137)
02-27 20:43:30.066: W/System.err(574): at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:208) 02-27 20:43:30.076: W/System.err(574): at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1076) 02-27 20:43:30.076: W/System.err(574): at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:569) 02-27 20:43:30.087: W/System.err(574): at java.lang.Thread.run(Thread.java:856) 02-27 20:43:30.108: W/System.err(574): Caused by: libcore.io.GaiException: getaddrinfo failed: EAI_NODATA (No address associated with hostname) 02-27 20:43:30.116: W/System.err(574): at libcore.io.Posix.getaddrinfo(Native Method) 02-27 20:43:30.116: W/System.err(574): at libcore.io.ForwardingOs.getaddrinfo(ForwardingOs.java:55) 02-27 20:43:30.126: W/System.err(574): at java.net.InetAddress.lookupHostByName(InetAddress.java:411) 02-27 20:43:30.126: W/System.err(574): ... 18 more 02-27 20:43:30.136: I/System.out(574): Except thrown by url http://search.twitter.com/search.json?q=javacodegeeks, .... 02-27 20:43:30.136: I/System.out(574): response =


Исключение составляет UnknownHostException, как вы можете видеть:
«ava.net.UnknownHostException: невозможно разрешить хост« search.twitter.com »: с именем хоста не связан адрес»
Но я не думаю, что этот сайт неприемлем ...

Кто-нибудь может сказать мне, что происходит + что мне нужно сделать, чтобы пройти через него?

10
задан Jason Robinson 15 April 2012 в 18:54
поделиться