HTTPCLIENT-2206: Corrected resource de-allocation by fluent response objects

This commit is contained in:
Oleg Kalnichevski 2022-02-26 14:54:26 +01:00
parent c4e480ef78
commit 73e72f2268
1 changed files with 17 additions and 10 deletions

View File

@ -26,6 +26,7 @@
*/ */
package org.apache.http.client.fluent; package org.apache.http.client.fluent;
import java.io.Closeable;
import java.io.File; import java.io.File;
import java.io.FileOutputStream; import java.io.FileOutputStream;
import java.io.IOException; import java.io.IOException;
@ -116,20 +117,26 @@ public class Response {
public void saveContent(final File file) throws IOException { public void saveContent(final File file) throws IOException {
assertNotConsumed(); assertNotConsumed();
final StatusLine statusLine = response.getStatusLine();
if (statusLine.getStatusCode() >= 300) {
throw new HttpResponseException(statusLine.getStatusCode(),
statusLine.getReasonPhrase());
}
final FileOutputStream out = new FileOutputStream(file);
try { try {
final HttpEntity entity = this.response.getEntity(); final StatusLine statusLine = response.getStatusLine();
if (entity != null) { if (statusLine.getStatusCode() >= 300) {
entity.writeTo(out); throw new HttpResponseException(statusLine.getStatusCode(),
statusLine.getReasonPhrase());
}
final FileOutputStream out = new FileOutputStream(file);
try {
final HttpEntity entity = this.response.getEntity();
if (entity != null) {
entity.writeTo(out);
}
} finally {
out.close();
} }
} finally { } finally {
this.consumed = true; this.consumed = true;
out.close(); if (this.response instanceof Closeable) {
((Closeable) this.response).close();
}
} }
} }