gpt4 book ai didi

java - WebLogic "Exceeded stated content length"错误

转载 作者:搜寻专家 更新时间:2023-11-01 02:18:26 26 4
gpt4 key购买 nike

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

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

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

查看此消息的末尾以获得完整的堆栈跟踪。

我们的环境是 WebLogic 10.0 和 Java 1.5(在 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();

//----

谢谢。

问候

布雷特 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)

最佳答案

感谢吉姆的回复。

解决方案是删除 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

关于java - WebLogic "Exceeded stated content length"错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1664996/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com