WebLogic“超出规定的内容长度”错误

时间:2009-11-03 03:06:34

标签: java weblogic

我有一个servlet过滤器,它在WebLogic 10.0中生成“超出规定的内容长度”错误。我将不胜感激任何解决此问题的建议。详情如下。

servlet过滤器调整图像大小。发生此错误然后将内容写入FileInputStream(从磁盘)到response.getOutputStream():

java.net.ProtocolException:超出规定的内容长度2228  在weblogic.servlet.internal.ChunkOutput.writeStream(ChunkOutput.java:411)

请参阅此消息的结尾以获取完整堆栈跟踪。

我们的环境是带有Java 1.5的WebLogic 10.0(在Windows XP上)。但是,我们已经在Tomcat 6,Java 1.6上使用了相同的servlet过滤器超过一年,所以没有任何问题。此外,我们使用WebLogic 8.1成功测试了此servlet过滤器的先前版本。

堆栈跟踪错误中指定的内容长度确实与磁盘上源文件的大小完全匹配。所以,我不知道内容长度是如何变得太大。

加载6张图片后,每张图片大小约为2kB,就会出现错误。所以,我确实想知道这个问题是否与我收集的WebLogic响应缓冲区大小有关,大约是12 kB。

我尝试使用response.setBufferSize()方法增加响应缓冲区大小。但是,WebLogic不会接受该命令,因为响应已经开始。有没有人知道在WebLogic中配置默认​​响应缓冲区大小的方法?

以下是代码的简化版本。我确实尝试添加out.flush(),但无济于事。是否有遗漏会导致WebLogic出现问题而不会导致Tomcat出现问题?

// ----

File file = new File(mFileName);
int fileLength = file.length();
response.setContentLength(fileLength);
response.setContentType(contentType);

OutputStream out = response.getOutputStream();

FileInputStream in = new FileInputStream(mFileName);

byte[] buf = new byte[1024];
int count = 0;

while ((count = in.read(buf)) >= 0) {

    out.write(buf, 0, count);
}

in.close();

out.close();

// ----

谢谢。

此致

Brett S

完整堆栈跟踪是:

####<3/11/2009 09:52:20 AM EST> <Error> <HTTP> <nmi02> <cgServer> <[ACTIVE] ExecuteThread: '1' for queue: 'weblogic.kernel.Default (self-tuning)'> <<WLS Kernel>> <> <> <1257202340094> <BEA-101019> <[weblogic.servlet.internal.WebAppServletContext@8615a2 - appName: '_workshop_auto_generated_ear_', name: '/', context-path: ''] Servlet failed with IOException
java.net.ProtocolException: Exceeded stated content length of 2228
 at weblogic.servlet.internal.ChunkOutput.writeStream(ChunkOutput.java:411)
 at weblogic.servlet.internal.ChunkOutputWrapper.writeStream(ChunkOutputWrapper.java:168)
 at weblogic.servlet.internal.ServletOutputStreamImpl.writeStream(ServletOutputStreamImpl.java:498)
 at weblogic.servlet.internal.ServletOutputStreamImpl.writeStream(ServletOutputStreamImpl.java:486)
 at weblogic.servlet.FileServlet.sendFile(FileServlet.java:407)
 at weblogic.servlet.FileServlet.doGetHeadPost(FileServlet.java:231)
 at weblogic.servlet.FileServlet.service(FileServlet.java:170)
 at javax.servlet.http.HttpServlet.service(HttpServlet.java:820)
 at weblogic.servlet.internal.StubSecurityHelper$ServletServiceAction.run(StubSecurityHelper.java:226)
 at weblogic.servlet.internal.StubSecurityHelper.invokeServlet(StubSecurityHelper.java:124)
 at weblogic.servlet.internal.ServletStubImpl.execute(ServletStubImpl.java:283)
 at weblogic.servlet.internal.TailFilter.doFilter(TailFilter.java:26)
 at weblogic.servlet.internal.FilterChainImpl.doFilter(FilterChainImpl.java:42)
 at com.nminnovation.nmf.images.ConverterFilter.doFilter(ConverterFilter.java:98)
 at weblogic.servlet.internal.FilterChainImpl.doFilter(FilterChainImpl.java:42)
 at com.nminnovation.nmf.util.CacheControlFilter.doFilter(CacheControlFilter.java:50)
 at weblogic.servlet.internal.FilterChainImpl.doFilter(FilterChainImpl.java:42)
 at weblogic.servlet.internal.WebAppServletContext$ServletInvocationAction.run(WebAppServletContext.java:3368)
 at weblogic.security.acl.internal.AuthenticatedSubject.doAs(AuthenticatedSubject.java:321)
 at weblogic.security.service.SecurityManager.runAs(Lweblogic.security.acl.internal.AuthenticatedSubject;Lweblogic.security.acl.internal.AuthenticatedSubject;Ljava.security.PrivilegedAction;)Ljava.lang.Object;(Unknown Source)
 at weblogic.servlet.internal.WebAppServletContext.securedExecute(WebAppServletContext.java:2117)
 at weblogic.servlet.internal.WebAppServletContext.execute(WebAppServletContext.java:2023)
 at weblogic.servlet.internal.ServletRequestImpl.run(ServletRequestImpl.java:1359)
 at weblogic.work.ExecuteThread.execute(ExecuteThread.java:200)
 at weblogic.work.ExecuteThread.run(ExecuteThread.java:172)

2 个答案:

答案 0 :(得分:4)

感谢你的回复吉姆。

解决方案是删除response.setContentLength()然后添加response.flushBuffer()

File file = new File(mFileName);
int fileLength = file.length();
//removed this line:
//response.setContentLength(fileLength);
response.setContentType(contentType);

OutputStream out = response.getOutputStream();

FileInputStream in = new FileInputStream(mFileName);            
byte[] buf = new byte[ fileLength ];
int count = 0;
while ((count = in.read(buf)) >= 0) {
    out.write(buf, 0, count);
}
in.close();
out.close();
//and added this line:
response.flushBuffer();

再次感谢。

关心Brett S

答案 1 :(得分:2)

Google搜索

weblogic "Exceeded stated content length"

出现了一些点击,其中最有趣的是here

总之,请在设置内容长度后尝试response.resetBuffer()