getHttpResponseCode ()возвращает -1 в Android 2.2

В моем приложении для Android я пытаюсь получить данные с сервера, выполнив запрос POST.

Я использую класс HttpURLConnectionдля выполнения запросов, поскольку Apache HttpClientбольше не поддерживается Android.

Вот что я делаю.

private boolean callWS() {
    try {

        // To avoid the bug in httpurlconnection prior froyo which
        // causes the getInputStream to return headers along with response
        if (Build.VERSION.SDK_INT < 8)
            System.setProperty("http.keepAlive", "false");

        mHttpResponseCode = 0;
        mErrorMessage = "";

        // Initialize connection
        URL connectURL = new URL(mServerUrl);

        HttpURLConnection conn = (HttpURLConnection) connectURL.openConnection();
        conn.setDoInput(true);
        conn.setDoOutput(true);
        conn.setUseCaches(false);
        conn.setInstanceFollowRedirects(true);
        conn.setReadTimeout(30000); 
        conn.setConnectTimeout(15000); 
        conn.setRequestMethod("POST");

        // Set some headers
        connection.setRequestProperty("Content-Type", "application/x-www-form-urlencoded");
        connection.setRequestProperty("Accept-Encoding", "deflate, gzip");
        connection.setRequestProperty("Content-Length", mParameters.length() + "");

        // Connect to host
        conn.connect();

        // Write parameters to connection
        OutputStreamWriter writer = new OutputStreamWriter(conn.getOutputStream());
        writer.write(mParameters);
        writer.flush();
        writer.close();

        // Wait for http response code
        mHttpResponseCode = conn.getResponseCode();

        // Read response from connection
        BufferedInputStream bis = new BufferedInputStream(conn.getInputStream());
        ByteArrayBuffer baf = new ByteArrayBuffer(50);
        int read = 0;
        int bufSize = 1024;
        byte[] buffer = new byte[bufSize];

        while (true) {
            read = bis.read(buffer);
            if (read == -1)
                break;
            baf.append(buffer, 0, read);
        }

        // Decompress gzipped response
        if (conn.getHeaderField("Content-Encoding") != null && conn.getHeaderField("Content-Encoding").contains("gzip"))
            mResponseString = decompress(baf.toByteArray());
        else
            mResponseString = new String(baf.toByteArray());

        mResponse.setResponse(mResponseString);         
        isWSCallSuccessfull = true;
    } catch(UnknownHostException unknownHostException) {
        isWSCallSuccessfull = false;
        mErrorMessage = "Unknown host exception";
        unknownHostException.printStackTrace();
        mLogger.putStacktrace(unknownHostException);
    } catch(SocketException socketException) {
        isWSCallSuccessfull = false;
        mErrorMessage = "Socket Exception";
        socketException.printStackTrace();
        mLogger.putStacktrace(socketException);
    } catch(SocketTimeoutException socketTimeOutException) {
        isWSCallSuccessfull = false;
        mErrorMessage = "Socket Timeout Exception";
        socketTimeOutException.printStackTrace();
        mLogger.putStacktrace(socketTimeOutException);
    } catch(SSLException sslException) {
        isWSCallSuccessfull = false;
        mErrorMessage = "SSL Exception";
        sslException.printStackTrace();
        mLogger.putStacktrace(sslException);
    } catch(IOException ioException) {
        isWSCallSuccessfull = false;
        mErrorMessage = "IO Exception " + ioException.getMessage();
        ioException.printStackTrace();
        mLogger.putStacktrace(ioException);
    }

    mResponse.setHttpResponseCode(mHttpResponseCode);
    mResponse.setErrorMessage(mErrorMessage);
    mResponse.isWSCallSuccessful(isWSCallSuccessfull);

    return isWSCallSuccessfull;
}

Это прекрасно работает на всех устройствах, за исключением устройств с 2.2 (, которые не пробовали на 2.1 ).

В 2.2 работает нормально. Но если я оставлю эту часть кода бездействующей более чем на 30 секунд, она вернет мне -1 в качестве кода ответа http в следующий раз.

Следует также отметить, что это происходит только с URL-адресами HTTPS, а не с URL-адресами HTTP. Я не хочу использовать класс HttpsURLConnection, потому что иногда мне может понадобиться и http.

Я не закрываю соединение только для того, чтобы поддерживать соединение. Что я делаю не так?

7
задан Sudarshan Bhat 11 March 2013 в 04:58
поделиться