“Connection already established” exception in HttpsURLConnection

后端 未结 2 1871
别跟我提以往
别跟我提以往 2021-01-19 13:16

I am trying to do a POST request using HttpsURLConnection, and get

java.net.ProtocolException: Connection already established

2条回答
  •  小蘑菇
    小蘑菇 (楼主)
    2021-01-19 14:09

    For anyone else who runs into this problem, I had an order of operations issue that only affected me when I was doing an HTTP POST that had content in the request body. It's not entirely clear in all scenarios when HttpURLConnection is actually initiating the connection to the server.

    My initial request looked like this:

            HttpURLConnection conn = null;
            try
            {
                conn = (HttpURLConnection) baseUrl.openConnection();  
                conn.setConnectTimeout(connectTimeoutMillis);
                conn.setReadTimeout(requestTimeoutMillis);
    
                //required for reading a response body
                conn.setDoInput(true);
    
                //Not all request types have a body (e.g. GET usually doesn't)
                if(requestBody != null && requestBody.length > 0)
                {
                    conn.setDoOutput(true);
                    conn.setFixedLengthStreamingMode(requestBody.length);
                    conn.getOutputStream().write(requestBody);
                    conn.getOutputStream().flush();
                    conn.getOutputStream().close();
                }
    
                try
                {
                    conn.setRequestMethod(verb.toUpperCase());
                }
                catch (final ProtocolException e)
                {
                    response.setError("Invalid HTTP verb \"" + verb + "\" received.","");
                    Log.e(TAG, response.errorMessage, e);
                    return response;
                }
    

    It turns out that you cannot call "conn.setRequestMethod(...)" after you've called "conn.getOutputStream()", so in my case, the simple fix was the call "conn.setRequestMethod(...)" before dealing with writing to the request body. The working code is:

    HttpURLConnection conn = null;
            try
            {
                conn = (HttpURLConnection) baseUrl.openConnection();  
                conn.setConnectTimeout(connectTimeoutMillis);
                conn.setReadTimeout(requestTimeoutMillis);
    
                //required for reading a response body
                conn.setDoInput(true);
    
                try
                {
                    conn.setRequestMethod(verb.toUpperCase());
                }
                catch (final ProtocolException e)
                {
                    response.setError("Invalid HTTP verb \"" + verb + "\" received.","");
                    Log.e(TAG, response.errorMessage, e);
                    return response;
                }
    
                //Not all request types have a body (e.g. GET usually doesn't)
                if(requestBody != null && requestBody.length > 0)
                {
                    conn.setDoOutput(true);
                    conn.setFixedLengthStreamingMode(requestBody.length);
                    conn.getOutputStream().write(requestBody);
                    conn.getOutputStream().flush();
                    conn.getOutputStream().close();
                }
    

    The only real change was just switching the ordering of calls and that got rid of the exception. Hopefully that fixes the issue for anyone else who had this problem.

提交回复
热议问题