IOException: сервер вернул 400 код ошибки - PullRequest
0 голосов
/ 03 июля 2019

Привет. Ниже приведен фрагмент кода. В приведенном ниже коде, когда я закрываю писатель после записи, сервер дает ожидаемые результаты. Но если он закрыт в блоке finally, он возвращает 400 неверных запросов. Есть ли причина для такого поведения?

BufferedReader br = null;
HttpURLConnection conn = null;
OutputStreamWriter writer = null;
String ip = "test"
try {
    URL url = new URL(http://someurl));
    conn = (HttpURLConnection) url.openConnection();
    conn.setDoInput(true);
    conn.setDoOutput(true);
    conn.setRequestMethod("POST");
    conn.setConnectTimeout(0);
    conn.setRequestProperty("Content-Type", "application/json");
    writer = new OutputStreamWriter(conn.getOutputStream(), "UTF-8");
    writer.write(ip);
    // writer.close();

    br = new BufferedReader(new InputStreamReader(conn.getInputStream()));

    String line;
    while ((line = br.readLine()) != null) {
        jsonString.append(line);
    }
} catch (final Exception e) {
    LOG.error("Error" + e);
}
finally 
{
    //Closing writer in finally block.
    if(writer != null)
    {
        try 
        {
            writer.close();
        } 
        catch (IOException e) {                      
            LOG.error("Error in closing Writer", e);
        }
    }
    if (br != null) 
    {
       try 
       {
            br.close();
        } 
        catch (final IOException e) 
        {
            LOG.error("Error: ", e);
        } 
    }
    if(conn != null){
        conn.disconnect();
    }             
}

1 Ответ

0 голосов
/ 03 июля 2019

Вам необходимо сбросить содержимое на сервер.Используйте writer.flush () вместо writer.close (), как только закончите с запросом на запись, непосредственно перед чтением ответа.

...