нет маршрута к хосту на устройстве на getOutputStream() - подключено по беспроводной сети

private String urlPost = "http://192.168.1.66:8080/DataCollectionServlet/";

@Override
protected void doWakefulWork(Intent intent) {
    // https://stackoverflow.com/q/14630255/281545
    HttpURLConnection connection = null;
    try {
        connection = connection();
        w("connection"); // allrigt
        final OutputStream connOutStream = connection.getOutputStream();
        w("GEToUTPUTsTREAM"); // I never see this
    } catch (IOException e) {
        e.printStackTrace(); // No route to host
    } finally {
        if (connection != null) connection.disconnect();
    }
}

private HttpURLConnection connection() throws MalformedURLException,
        IOException {
    HttpURLConnection connection = (HttpURLConnection) new URL(urlPost)
            .openConnection();
    // connection.setDoInput(true);
    connection.setDoOutput(true); // triggers POST
    // connection.setUseCaches(false); // needed ?
    // TODO : http://www.w3.org/Protocols/rfc2616/rfc2616-sec14.html
    // connection.setRequestProperty("Connection", "Keep-Alive");
    // connection.setRequestProperty("User-Agent",
    // "Android Multipart HTTP Client 1.1"); // needed ?
    return connection;
}

Сервер в 192.168.1.66:8080/DataCollectionServlet/ запущен и работает. Мой IP-адрес устройства192.168.1.65. Я отключил оба окна и брандмауэр маршрутизатора безрезультатно.

РЕДАКТИРОВАТЬ - трассировка стека:

java.net.SocketException: No route to host
at org.apache.harmony.luni.platform.OSNetworkSystem.connect(Native Method)
at dalvik.system.BlockGuard$WrappedNetworkSystem.connect(BlockGuard.java:357)
at org.apache.harmony.luni.net.PlainSocketImpl.connect(PlainSocketImpl.java:204)
at org.apache.harmony.luni.net.PlainSocketImpl.connect(PlainSocketImpl.java:437)
at java.net.Socket.connect(Socket.java:983)
at org.apache.harmony.luni.internal.net.www.protocol.http.HttpConnection.<init>(HttpConnection.java:75)
at org.apache.harmony.luni.internal.net.www.protocol.http.HttpConnection.<init>(HttpConnection.java:48)
at org.apache.harmony.luni.internal.net.www.protocol.http.HttpConnection$Address.connect(HttpConnection.java:322)
at org.apache.harmony.luni.internal.net.www.protocol.http.HttpConnectionPool.get(HttpConnectionPool.java:89)
at org.apache.harmony.luni.internal.net.www.protocol.http.HttpURLConnectionImpl.getHttpConnection(HttpURLConnectionImpl.java:285)
at org.apache.harmony.luni.internal.net.www.protocol.http.HttpURLConnectionImpl.makeConnection(HttpURLConnectionImpl.java:267)
at org.apache.harmony.luni.internal.net.www.protocol.http.HttpURLConnectionImpl.connect(HttpURLConnectionImpl.java:205)
at org.apache.harmony.luni.internal.net.www.protocol.http.HttpURLConnectionImpl.getOutputStream(HttpURLConnectionImpl.java:614)
at gr.uoa.di.monitoring.android.services.NetworkService.doWakefulWork(NetworkService.java:51)
at com.commonsware.cwac.wakeful.WakefulIntentService.onHandleIntent(WakefulIntentService.java:94)
at android.app.IntentService$ServiceHandler.handleMessage(IntentService.java:59)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:130)
at android.os.HandlerThread.run(HandlerThread.java:60)

Комментарии: Опять же, телефон и ПК подключены к одному и тому же маршрутизатору по беспроводной сети (один и тот же SSID).

Android 2.3.7 Eclair, HTC Nexus 1 — может ли это быть ошибкой?

РЕДАКТИРОВАТЬ 2013.11.13: все еще интересует объяснение мой ответ


person Mr_and_Mrs_D    schedule 01.09.2013    source источник
comment
Кажется, что ваше устройство находится не в вашей локальной сети, а в отдельной сети (общедоступной или иным образом отделенной). У вас включен WLAN? И подключен ли он к WLAN вашей локальной сети?   -  person Codo    schedule 01.09.2013
comment
@Codo: компьютер 192.168.1.66, а телефон 192.168.1.65 - они оба подключены к одному и тому же маршрутизатору по беспроводной сети, да (один и тот же SSID)   -  person Mr_and_Mrs_D    schedule 01.09.2013
comment
Вы пытались ввести URL-адрес в браузер устройства Android?   -  person Moog    schedule 01.09.2013
comment
@Merlin: Да (http://192.168.1.66:8080/DataCollectionServlet/datacollection) — веб-страница недоступна   -  person Mr_and_Mrs_D    schedule 01.09.2013
comment
Они оба подключены по беспроводной сети или, возможно, на вашем маршрутизаторе есть блокировка между LAN / WLAN?   -  person Moog    schedule 01.09.2013
comment
@Merlin: оба по беспроводной сети - может ли это быть связано с моим проектом сервлета?   -  person Mr_and_Mrs_D    schedule 01.09.2013


Ответы (1)


Ну ладно - отключив (WPA-PSK) шифрование на роутере подключаюсь нормально. Я бы принял в качестве ответа (программную) работу

РЕДАКТИРОВАТЬ: введя URL-адрес в браузер устройства Android, я вижу страницу doGet(). Я снова включил все брандмауэры - единственное, что имеет значение, это включение и выключение шифрования.

person Mr_and_Mrs_D    schedule 15.09.2013