Android RestTemplate Ok on emulator but fails on real device

Posted by Hossein on Stack Overflow See other posts from Stack Overflow or by Hossein
Published on 2012-06-15T19:22:15Z Indexed on 2012/06/15 21:16 UTC
Read the original article Hit count: 591

I'm using spring RestTemplate and it works perfect on emulator but if I run my app on real device I get

HttpMessageNotWritableException ............ nested exception is java.net.SocketException: Broken pipe

Here is some lines of my code(keep in mind my app works perfect on emulator)

............

LoggerUtil.logToFile(TAG, "url is [" + url + "]");

LoggerUtil.logToFile(TAG, "NetworkInfo - " + connectivityManager.getActiveNetworkInfo());

ResponseEntity<T> responseEntity = restTemplate.exchange(url,
                HttpMethod.POST, requestEntity, clazz);

.............

I know my device's network works perfect because all other applications on my device are working and also using device browser I'm able to connect to my server so my server is available.

My server is up and running and my device is able to connect to my server so why I get

java.net.SocketException: Broken pipe ?!!!!!!!

Before I call restTemplate.exchange() I log NetworkInfo and it looks ok

-type: WIFI

-status: CONNECTED/CONNECTED

-isAvailable: true

Thanks in advance.

Update: It is really weird Even if I use HttpURLConnection, it works perfectly on emulator but on real device I get 400 Bad Request Here is my code HttpURLConnection con = null;

    try {
        String url = ....;
        LoggerUtil.logToFile(TAG, "url [" + url + "]" );
        con = (HttpURLConnection) new URL(url).openConnection();
        con.setRequestMethod("POST");
        con.setRequestProperty("Connection", "Keep-Alive");
        con.setDoInput(true);
        con.setDoOutput(true);
        con.setUseCaches(false);

        con.connect();

        LoggerUtil.logToFile(TAG, "con.getResponseCode is " + con.getResponseCode());
        LoggerUtil.logToFile(TAG, "con.getResponseMessage is " + con.getResponseMessage());

    }
    catch(Throwable t){
        LoggerUtil.logToFile(TAG, "*** failed [" + t + "]" );
    }

in log file I see con.getResponseCode is 400 con.getResponseMessage is Bad Request

© Stack Overflow or respective owner

Related posts about android

Related posts about socketexception