weblogic“超出声明的内容长度”错误

vulvrdjw  于 2021-07-05  发布在  Java
关注(0)|答案(2)|浏览(712)

我有一个servlet过滤器,它在weblogic10.0中生成“超出声明的内容长度”错误。如果您能提出任何建议来解决这个问题,我将不胜感激。详情如下。
servlet过滤器调整图像大小。将fileinputstream(从磁盘)中的内容写入response.getoutputstream()时发生此错误:
java.net.protocolexception:超出weblogic.servlet.internal.chunkoutput.writestream(chunkoutput)中声明的2228内容长度。java:411)
有关完整堆栈跟踪,请参阅此消息的结尾。
我们的环境是weblogic10.0和java1.5(在windowsxp上)。然而,我们已经在tomcat6、java1.6上使用相同的servlet过滤器一年多了,所以没有任何问题。此外,我们还成功地用weblogic8.1测试了这个servlet过滤器的早期版本。
堆栈跟踪错误中声明的内容长度确实与磁盘上源文件的大小精确匹配。所以,我不知道内容长度是怎么变得太大的。
错误发生在加载6个图像后,每个图像大小约为2kb。所以,我想知道这个问题是否与weblogic响应缓冲区大小有关,我收集的缓冲区大小大约为12kb。
我尝试使用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();

//----
谢谢您。
当做
布雷特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)
smdncfj3

smdncfj31#

谢谢你的回复,吉姆。
解决方案是删除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();

再次感谢。
问候布雷特

bxfogqkk

bxfogqkk2#

谷歌搜索

weblogic "Exceeded stated content length"

出现了很多点击率,其中最有趣的是这里。
总之,试着去做 response.resetBuffer() 设置内容长度后。

相关问题