私はHttpUrlConnection
を使用して、アンドロイドアプリケーションからネットワークリクエストを作成しています。 1つのことを除いてすべて正常に動作します。401サーバーがステータスコード401の応答を返すと、私のアプリはというメッセージでIOException
をスローします。グーグルでそれを行った後、私は単一の解決策を見つけられませんでしたが、回避策(try/catchを使用して処理します。ここandroidでtry/catchを使用して401レスポンスを取得する方法
は、コードスニペットです:
public Bundle request(String action, Bundle params, String cookie) throws FileNotFoundException, MalformedURLException, SocketTimeoutException,
IOException {
OutputStream os;
String url = baseUrl + action;
Log.d(TAG, url);
HttpURLConnection conn = (HttpURLConnection) new URL(url).openConnection();
conn.setConnectTimeout(30 * 1000);
conn.setReadTimeout(30 * 1000);
conn.setRequestProperty("User-Agent", System.getProperties().getProperty("http.agent") + "AndroidNative");
conn.setRequestMethod("POST");
conn.setRequestProperty("Content-Type", "multipart/form-data;boundary=" + boundary);
conn.setRequestProperty("Connection", "Keep-Alive");
conn.setDoOutput(true);
conn.setDoInput(true);
if (cookie != null) {
conn.setRequestProperty("Cookie", cookie);
}
if (params != null) {
os = conn.getOutputStream();
os.write(("--" + boundary + endLine).getBytes());
os.write((encodePostBody(params, boundary)).getBytes());
os.write((endLine + "--" + boundary + endLine).getBytes());
uploadFile(params, os);
os.flush();
os.close();
}
conn.connect();
Bundle response = new Bundle();
try {
response.putInt("response_code", conn.getResponseCode());
Log.d(TAG, conn.getResponseCode() + "");
response.putString("json_response", read(conn.getInputStream()));
List<String> responseCookie = conn.getHeaderFields().get("set-cookie");
// Log.d(TAG, responseCookie.get(responseCookie.size() - 1));
response.putString("cookie", responseCookie.get(responseCookie.size() - 1));
} catch (SocketTimeoutException e) {
throw new SocketTimeoutException(e.getLocalizedMessage());
} catch (FileNotFoundException e) {
throw new FileNotFoundException(e.getLocalizedMessage());
} catch (IOException e) {
e.printStackTrace();
response.putInt("response_code", HttpURLConnection.HTTP_UNAUTHORIZED);
response.putString("json_response", read(conn.getErrorStream()));
}
// debug
Map<String, List<String>> map = conn.getHeaderFields();
for (String key : map.keySet()) {
List<String> values = map.get(key);
for (String value : values) {
Log.d(key, value);
}
}
conn.disconnect();
return response;
}
この例外がスローされた理由を私は本当に、知りたいですか?認証チャレンジは何を意味しますか?どのように認証の挑戦を提供する?この状況を克服するためにコード内でどのような変更を行う必要がありますか?
私を啓発してください。.. :)
私はそれは、サーバーが401エラーコードで応答したが、認証チャレンジを記述する 'WWW-Authenticate'ヘッダを省略することを意味推測すると思います。 – Jens
サーバは 'WWW-Authenticate'ヘッダを持っていますが、依然としてこのエラーが発生しています。 – jtanveer
私はちょうどこれに出くわしました。また、この応答コードを取得する方法を理解することもできません。なぜなら、 'getResponseCode()'自身が 'connect()/'と同じIOExceptionをスローするので、 getInputStream()/ getOutputStream() ')を呼び出します。 stacktraceからは、 'org.apache.harmony.luni.internal.net.www.protocol.http.HttpURLConnectionImpl.processAuthHeader(HttpURLConnectionImpl.java:1153)'がチェーンの上に例外をスローするようになっています(ただし、さらに潜水する)。 –