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); ''が呼び出されるたびに、プログラムが例外をスローしてキャッチすることです。役に立たない!
私は2つのことを聞いた:
1)エミュレーター/デバイスがインターネットを使用するための許可を設定する必要があります! -私はこれをカバーしたと思いますが、多分私はそれを間違えました! androidmanifest.xmlに追加しました
< uses-permission Android:name="Android.permission.INTERNET" >< /uses-permission>
だからそれがあります。
2)(私にはよくわかりませんが)「ui」スレッド内で「ネットワーキング」スレッドを開始することはできません。これが何を意味するのか完全にはわかりませんが、先に進んでAndroidスレッド、ハンドラー、AsyncTasksに関するチュートリアルに従いました。ここで:私が従ったAsyncTaskチュートリアルの下のコードを確認してください。 :
http://www.vogella.de/articles/AndroidPerformance/article.html
AsyncTaskチュートリアルを実行した後、私はまだ同じ問題を抱えていることに気付きました-
次の行:HttpGet httpGet = new HttpGet(url)は、以前と同様に常に例外をスローしました。
上記のスレッドチュートリアルでの私の試みからのlogcatは次のとおりです。
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 =
次のように、例外はUnknownHostExceptionです。
"ava.net.UnknownHostException:ホスト" search.Twitter.com "を解決できません:ホスト名に関連付けられたアドレスがありません"
しかし、このサイトは受け入れられないと思います...
誰かが私に何が起こっているのか+それを乗り越えるために何をする必要があるのか教えてもらえますか?
マニフェストの権限を確認し、これを追加したことを確認してください。
<uses-permission Android:name="Android.permission.ACCESS_NETWORK_STATE"/>
<uses-permission Android:name="Android.permission.ACCESS_WIFI_STATE"/>
<uses-permission Android:name="Android.permission.INTERNET"/>
理解した。どうやら私はAVDを「機内モード」からオフにしました。
私と同じ問題を抱えている人は、おそらくワイヤレスを使用しています。何らかの理由でAndroidはLANカードを見るので、ネットワーク接続に移動してLANカードを右クリックします-それを無効にしてください!問題は解決しました。
問題は、httpリクエストまたはインターネット接続で指定したURLにあると思います。以下のリンクを確認してください リンク
私もこの問題に遭遇しました。私の場合、HttpURLConnectionを使用してJSONをロードしています。 「リダイレクトに従う」を有効にすると、この問題は修正されました。動作するコードスニペットは次のとおりです。
HttpURLConnection connection = null;
BufferedReader reader = null;
String JSON_data = null;
try {
final int half_hour = 30 * 60;
URL fetch = new URL(requestUrl);
connection = (HttpURLConnection) fetch.openConnection();
// FIXED: request to follow redirects - this seems to solve networking issues on older devices < API 21
connection.setInstanceFollowRedirects(true);
connection.setUseCaches(true);
connection.setDefaultUseCaches(true);
connection.setRequestMethod("GET");
connection.addRequestProperty("Cache-Control", "max-age="+half_hour);
connection.addRequestProperty("X-Auth-Token", getString(R.string.api_key));
boolean redirect = false;
int status = connection.getResponseCode();
if (status != HttpURLConnection.HTTP_OK) {
if (status == HttpURLConnection.HTTP_MOVED_TEMP
|| status == HttpURLConnection.HTTP_MOVED_PERM
|| status == HttpURLConnection.HTTP_SEE_OTHER)
redirect = true;
}
Log.d(TAG, "===> HTTP STATUS CODE: " + status + ", redirect=" + redirect);
connection.connect();
// Read the input stream into a String
InputStream inputStream = connection.getInputStream();
if (inputStream == null) {
return;
}
reader = new BufferedReader(new InputStreamReader(inputStream));
StringBuilder buffer = new StringBuilder();
String line;
while ((line = reader.readLine()) != null) {
buffer.append(line);
buffer.append("\n");
}
if (buffer.length() == 0) {
return;
}
JSON_data = buffer.toString();
Log.d(TAG, "JSON_data=" + JSON_data);
} catch (Exception e) {
// possible UnknownHostException on older Android device?
Log.e(TAG, "HttpURLConnection Exception - e=" + e.getMessage());
e.printStackTrace();
} finally {
if (connection != null) {
connection.disconnect();
}
if (reader != null) {
try {
reader.close();
} catch (IOException e) {
Log.e(TAG, "Error closing stream - e=" + e.getMessage());
}
}
}
アプリに問題があるわけではありません。Wi-Fiインターネットを使用しているためです。これを解決するには、ラップトップをWi-Fiに接続したままにして、エミュレータを再起動します。
それは私のために働いた