Commit f8df3378 by Jean-Eric Cuendet Committed by Dave Syer

Verify that the stream is more than ZERO bytes before un-gzipping

Fixes gh-891
parent 3c8a0d0e
...@@ -125,17 +125,25 @@ public class SendResponseFilter extends ZuulFilter { ...@@ -125,17 +125,25 @@ public class SendResponseFilter extends ZuulFilter {
// before sending to client // before sending to client
// else, stream gzip directly to client // else, stream gzip directly to client
if (context.getResponseGZipped() && !isGzipRequested) { if (context.getResponseGZipped() && !isGzipRequested) {
try { // If origin tell it's GZipped but the content is ZERO bytes,
inputStream = new GZIPInputStream(is); // don't try to uncompress
final Long len = context.getOriginContentLength();
if (len == null || len > 0) {
try {
inputStream = new GZIPInputStream(is);
}
catch (java.util.zip.ZipException ex) {
log.debug(
"gzip expected but not "
+ "received assuming unencoded response "
+ RequestContext.getCurrentContext()
.getRequest().getRequestURL()
.toString());
inputStream = is;
}
} }
catch (java.util.zip.ZipException ex) { else {
log.debug( // Already done : inputStream = is;
"gzip expected but not "
+ "received assuming unencoded response "
+ RequestContext.getCurrentContext()
.getRequest().getRequestURL()
.toString());
inputStream = is;
} }
} }
else if (context.getResponseGZipped() && isGzipRequested) { else if (context.getResponseGZipped() && isGzipRequested) {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment