Pracuję nad projektem Android i jestem w punkcie, w którym chcę poprosić niektóre API o informacje. Wydaje się, że to powinno być bardzo proste!HttpResponse za pomocą android wydania: wykonanie zawsze powoduje wyjątek?
Oto ogólny sens mojego kodu:
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;
}
gdzie zmienna url jest łańcuch "http://search.twitter.com/search.json?q=javacodegeeks".
Jak widać, na stronie jest kilka fajnych informacji o JSON; Mój problem polega na tym, że za każdym razem, gdy wywoływany jest '' client.execute (getRequest); '', program wyrzuca i przechwytuje wyjątek. Nieprzydatne!
Słyszałem dwie rzeczy:
1) Musisz ustawić uprawnienia dla emulatora/urządzenia do korzystania z Internetu! - Myślę, że to omówiłem, ale może zrobiłem to źle! W AndroidManifest.xml dodałem
< uses-permission android:name="android.permission.INTERNET" >< /uses-permission>
Więc nie o to chodzi.
2) (o czym nie jestem przekonany), nie można uruchomić wątku "sieciowego" wewnątrz wątku "ui". Nie jestem do końca pewien, co to oznacza, ale poszedłem do przodu i poszedłem za przykładem samouczka na temat wątków Androida, Handlerów i AsyncTasks. Tutaj: Proszę sprawdzić kod pod tutorialu AsyncTask, którą następnie:
http://www.vogella.de/articles/AndroidPerformance/article.html
Po wykonaniu wraz z samouczka AsyncTask, stwierdziliśmy, że nadal miał ten sam problem--
linię : HttpGet httpGet = new HttpGet (url) zawsze wyrzucał wyjątek, jak poprzednio.
Oto logcat z mojej próbie z samouczka gwintowania powyżej:
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)<br/>
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)<br/>
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 =
Wyjątkiem jest UnknownHostException jak widać:
„ava.net.UnknownHostException: Nie można rozwiązać hosta” search.twitter.com „: Brak adresu powiązany z nazwą hosta”
Ale nie sądzę, że witryna jest niedopuszczalne ...
ktoś może mi powiedzieć, co się dzieje + co muszę d o przejść przez to?
czym są wyjątki i śledzenie stosu? –
Dodałem kod logcat do oryginalnego pytania, ponieważ jest długi. –
Dodanie uprawnień rozwiązało to dla mnie. Ale pamiętaj, aby zmienić tę linię: ' uses-permission>' to ' uses-permission>' –