java.net.UnknownHostException с использованием AsyncHttpClient
Я пытаюсь отправить запрос на стороне сервера со стороны клиента Android, используя AsyncHttpClient:
Сейчас я просто хочу проверить, возвращается ответ или нет, поэтому я не реализовал ничего, чтобы проанализировать параметры запроса на стороне сервера, и только что возвратил некоторый JSON в качестве ответа.
RequestParams params = new RequestParams();
params.put("key", "value");
params.put("more", "data");
PAAPI.post("http://sairav.pythonanywhere.com",params, new JsonHttpResponseHandler() {
@Override
public void onSuccess(int statusCode, Header[] headers, JSONObject response) {
// If the response is JSONObject instead of expected JSONArray
Log.d("Response::",response.toString());
Toast.makeText(act,response.toString(),Toast.LENGTH_LONG).show();
}
@Override
public void onStart() {
// called before request is started
Toast.makeText(act,"Going to make API CALL",Toast.LENGTH_LONG).show();
}
@Override
public void onFailure(int statusCode, Header[] headers, String responseString, Throwable throwable) {
super.onFailure(statusCode, headers, responseString, throwable);
Log.d("Failed: ", ""+statusCode);
Log.d("Error : ", "" + throwable);
}
@Override
public void onSuccess(int statusCode, Header[] headers, JSONArray timeline) {
// Pull out the first event on the public timeline
JSONObject firstEvent = null;
try {
firstEvent = timeline.getJSONObject(0);
} catch (JSONException e) {
e.printStackTrace();
}
String tweetText = null;
try {
tweetText = firstEvent.getString("text");
} catch (JSONException e) {
e.printStackTrace();
}
// Do something with the response
Toast.makeText(act,tweetText,Toast.LENGTH_LONG).show();
}
});
Класс PAAPI::
class PAAPI {
protected static final String BASE_URL = "http://sairav.pythonanywhere.com";
private static AsyncHttpClient client = new AsyncHttpClient();
public static void get(String url, RequestParams params, AsyncHttpResponseHandler responseHandler) {
client.get(getAbsoluteUrl(url), params, responseHandler);
}
public static void post(String url, RequestParams params, AsyncHttpResponseHandler responseHandler) {
client.post(getAbsoluteUrl(url), params, responseHandler);
}
private static String getAbsoluteUrl(String relativeUrl) {
return BASE_URL + relativeUrl;
}
}
Я получаю тост из onStart при запуске приложения, но затем в logcat я получаю следующее исключение: java.net.UnknownHostException: невозможно разрешить хост " sairav.pythonanywhere.comhttp ": нет адреса, связанного с именем хоста
Примечание. Я уже сбросил соединение Wi-Fi и снова запущен (при поиске других похожих вопросов), но проблема не устранена.
Logcat:
24154-24228/com.example.sairav.moneytor W/System.err: java.net.UnknownHostException: Unable to resolve host "sairav.pythonanywhere.comhttp": No address associated with hostname
09-01 23:32:11.718 24154-24228/com.example.sairav.moneytor W/System.err: at java.net.InetAddress.lookupHostByName(InetAddress.java:440)
09-01 23:32:11.718 24154-24228/com.example.sairav.moneytor W/System.err: at java.net.InetAddress.getAllByNameImpl(InetAddress.java:252)
09-01 23:32:11.718 24154-24228/com.example.sairav.moneytor W/System.err: at java.net.InetAddress.getAllByName(InetAddress.java:215)
09-01 23:32:11.718 24154-24228/com.example.sairav.moneytor W/System.err: at cz.msebera.android.httpclient.impl.conn.SystemDefaultDnsResolver.resolve(SystemDefaultDnsResolver.java:44)
09-01 23:32:11.718 24154-24228/com.example.sairav.moneytor W/System.err: at cz.msebera.android.httpclient.impl.conn.DefaultClientConnectionOperator.resolveHostname(DefaultClientConnectionOperator.java:259)
09-01 23:32:11.718 24154-24228/com.example.sairav.moneytor W/System.err: at cz.msebera.android.httpclient.impl.conn.DefaultClientConnectionOperator.openConnection(DefaultClientConnectionOperator.java:159)
09-01 23:32:11.718 24154-24228/com.example.sairav.moneytor W/System.err: at cz.msebera.android.httpclient.impl.conn.AbstractPoolEntry.open(AbstractPoolEntry.java:145)
09-01 23:32:11.718 24154-24228/com.example.sairav.moneytor W/System.err: at cz.msebera.android.httpclient.impl.conn.AbstractPooledConnAdapter.open(AbstractPooledConnAdapter.java:131)
09-01 23:32:11.718 24154-24228/com.example.sairav.moneytor W/System.err: at cz.msebera.android.httpclient.impl.client.DefaultRequestDirector.tryConnect(DefaultRequestDirector.java:611)
09-01 23:32:11.718 24154-24228/com.example.sairav.moneytor W/System.err: at cz.msebera.android.httpclient.impl.client.DefaultRequestDirector.execute(DefaultRequestDirector.java:446)
09-01 23:32:11.718 24154-24228/com.example.sairav.moneytor W/System.err: at cz.msebera.android.httpclient.impl.client.AbstractHttpClient.doExecute(AbstractHttpClient.java:860)
09-01 23:32:11.718 24154-24228/com.example.sairav.moneytor W/System.err: at cz.msebera.android.httpclient.impl.client.CloseableHttpClient.execute(CloseableHttpClient.java:82)
09-01 23:32:11.718 24154-24228/com.example.sairav.moneytor W/System.err: at com.loopj.android.http.AsyncHttpRequest.makeRequest(AsyncHttpRequest.java:146)
09-01 23:32:11.718 24154-24228/com.example.sairav.moneytor W/System.err: at com.loopj.android.http.AsyncHttpRequest.makeRequestWithRetries(AsyncHttpRequest.java:177)
09-01 23:32:11.718 24154-24228/com.example.sairav.moneytor W/System.err: at com.loopj.android.http.AsyncHttpRequest.run(AsyncHttpRequest.java:106)
2 ответа
Одна вещь, которую я могу видеть в PAAPI.post
звонок звонит getabsoluteUrl
который добавляет базовый URL с переданным URL.
Это определенно неправильно. Это приведет к sairav.pythonanywhere.comhttp://sairav.pythonanywhere.com
Удалить getAbsoluteUrl()
метод из post()
Причина Это приведет к sairav.pythonanywhere.comhttp://sairav.pythonanywhere.com