X-Git-Url: https://juplo.de/gitweb/?p=percentcodec;a=blobdiff_plain;f=cachecontrol%2Fsrc%2Fmain%2Fjava%2Fde%2Fhalbekunst%2Fjuplo%2Fcachecontrol%2FAcceleratorFilter.java;h=63edfb59d536a6ce3bd4e4bb1c7ffd4957ed7e0e;hp=ffafddc7d382f2b6fc26b64ba81a4535cb007dae;hb=3f484068bb529558fbfce8043ed63e8dbf58cb61;hpb=192d7e5f83aed0c651400f393fd000f15f72fc10 diff --git a/cachecontrol/src/main/java/de/halbekunst/juplo/cachecontrol/AcceleratorFilter.java b/cachecontrol/src/main/java/de/halbekunst/juplo/cachecontrol/AcceleratorFilter.java index ffafddc7..63edfb59 100644 --- a/cachecontrol/src/main/java/de/halbekunst/juplo/cachecontrol/AcceleratorFilter.java +++ b/cachecontrol/src/main/java/de/halbekunst/juplo/cachecontrol/AcceleratorFilter.java @@ -62,14 +62,6 @@ public class AcceleratorFilter implements Filter { return; } - // TODO: Das macht so wahrscheinlich keinen Sinn... - /** Prüfen, ob es sich um eine Anfrage für einen JSP-Include handelt */ - if (request.getAttribute(REQUEST_URI_ATTRIBUTE) != null) { - log.debug("Includes cannot be accelerated"); - chain.doFilter(request, response); - return; - } - HttpServletRequest httpRequest = (HttpServletRequest)request; HttpServletResponse httpResponse = (HttpServletResponse)response; AccelerationWrapper wrapper = new AccelerationWrapper(httpRequest, httpResponse); @@ -333,6 +325,7 @@ public class AcceleratorFilter implements Filter { */ response.reset(); pos = 0; + size = 0; stream = null; writer = null; } @@ -649,9 +642,11 @@ public class AcceleratorFilter implements Filter { public void write(int i) throws IOException { if (pos == bufferSize) { out().write(buffer); - pos = 0; committed = true; - cacheControl.decorate(request, response); + /** Dekoration nur beim ersten Schreib-Schub anstoßen */ + if (pos == size) + cacheControl.decorate(request, response); + pos = 0; } buffer[pos++] = (byte) i; size++; @@ -663,7 +658,9 @@ public class AcceleratorFilter implements Filter { return; committed = true; - cacheControl.decorate(request, response); + /** Dekoration nur beim ersten Schreib-Schub anstoßen */ + if (pos == size) + cacheControl.decorate(request, response); out().write(buffer, 0, pos); out().flush(); pos = 0;