tomcat 启动异常 EOFException: Unexpected end of ZLIB input stream

本文解析了Tomcat中出现的EOFException及ZipException错误原因,并提供了详细的解决方案,包括如何清理缓存以解决页面更新不生效的问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

EVERE: Exception fixing docBase for context [/agdis]
java.io 

.EOFException: Unexpected end of ZLIB input stream
    at java.util.zip.ZipFile$ZipFileInflaterInputStream.fill(ZipFile.java:413)
    at java.util.zip.InflaterInputStream.read(InflaterInputStream.java:158)
    at java.io 

.FilterInputStream.read(FilterInputStream.java:107)
    at org.apache.catalina.startup.ExpandWar.expand(ExpandWar.java:413)
    at org.apache.catalina.startup.ExpandWar.expand(ExpandWar.java:144)
    at org.apache.catalina.startup.ContextConfig.fixDocBase(ContextConfig.java:735)
    at org.apache.catalina.startup.ContextConfig.beforeStart(ContextConfig.java:863)
    at org.apache.catalina.startup.ContextConfig.lifecycleEvent(ContextConfig.java:388)
    at org.apache.catalina.util.LifecycleSupport.fireLifecycleEvent(LifecycleSupport.java:117)
    at org.apache.catalina.util.LifecycleBase.fireLifecycleEvent(LifecycleBase.java:90)
    at org.apache.catalina.util.LifecycleBase.setStateInternal(LifecycleBase.java:402)
    at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:147)
    at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:901)
    at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:877)
    at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:652)
    at org.apache.catalina.startup.HostConfig.deployWAR(HostConfig.java:1095)
    at org.apache.catalina.startup.HostConfig$DeployWar.run(HostConfig.java:1930)
    at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:471)
    at java.util.concurrent.FutureTask.run(FutureTask.java:262)
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)
    at java.lang.Thread.run(Thread.java:745)

Jan 18, 2018 10:23:58 AM org.apache.catalina.core.StandardContext startInternal
SEVERE: Error while attempting to validate required application extensions
java.io 

.IOException: Jar: commons-codec-1.5.jar
    at org.apache.catalina.util.ExtensionValidator.validateApplication(ExtensionValidator.java:205)
    at org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5339)
    at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150)
    at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:901)
    at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:877)
    at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:652)
    at org.apache.catalina.startup.HostConfig.deployWAR(HostConfig.java:1095)
    at org.apache.catalina.startup.HostConfig$DeployWar.run(HostConfig.java:1930)
    at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:471)
    at java.util.concurrent.FutureTask.run(FutureTask.java:262)
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)
    at java.lang.Thread.run(Thread.java:745)
Caused by: java.util.zip.ZipException: invalid LOC header (bad signature)
    at java.util.zip.ZipFile.read(Native Method)
    at java.util.zip.ZipFile.access$1400(ZipFile.java:56)
    at java.util.zip.ZipFile$ZipFileInputStream.read(ZipFile.java:679)
    at java.util.zip.ZipFile$ZipFileInflaterInputStream.fill(ZipFile.java:415)
    at java.util.zip.InflaterInputStream.read(InflaterInputStream.java:158)
    at java.io 

.FilterInputStream.read(FilterInputStream.java:133)
    at java.io 

.PushbackInputStream.read(PushbackInputStream.java:186)
    at java.util.zip.ZipInputStream.readFully(ZipInputStream.java:424)
    at java.util.zip.ZipInputStream.readLOC(ZipInputStream.java:277)

 

session未超时的情况下,服务器关闭的时候会被序列化为工程名\SESSIONS.ser,tomcat 启动的时候再加载进来,EOFException表示tomcat上次关闭时还有一些活动连接,所以在重启时tomcat尝试去恢复这些session,但是在输入过程中意外地到达文件尾或流尾的信号,导致从session中获取数据失败。异常是tomcat本身的问题,由于tomcat上次非正常关闭时有一些活动session被持 久化(表现为一些临时文件),在重启时,tomcat尝试去恢复这些session的持久化数据但又读取失败造成的。此异常不影响系统的使用。

解决办法:将 tomcat_home\work\Catalina\localhost\『工程名』\SESSIONS.ser删除。如果正常关闭服务端,该文件是自 动删除的。考虑到每个人的tomat的工作目录不同,建议在“搜索”功能中找到你的SESSIONS.ser文件,而且只需要删 除..\yourProjectName\下的SESSIONS.ser即可。 

最简单的办法是work下的全部删除,然后重启tomcat。

 

 用tomcat作web服务器的时候,部署的程序在webApps下,这些程序都是编译后的程序(发布到tomcat的项目里含的类,会被编译成.class后才发布过来,源文件没有发布过来,但这里的jsp没有经编译的)。tomcat有一个work目录,里面存放了页面的缓存,访问的jsp都会编译(从work里进入Catalina后的如localhost站点文件夹下的项目,我们可以看到那些jsp 页面会被编译成应该是servlet文件,下次再来访问时,就直接运行servlet类就可以向客户端反应响应页面了,所以有的博客说第一次访问时会比较 慢,是因为新发布上去的页面在第一个人访问时,会先编译成servlet文件,所以慢了,一旦编译好,那么除非jsp页面修改,不然下次访问直接运行 servlet就可以响应用户,所以快),编译后的文件都会存储在work目录下。而tomcat显示的目录,都会从这个缓存里找编译后的jsp对应的class文件。所以当清空了work目录后,该过程将会从新来过。     
    有的时候会遇到一个问题,就是修改后的页面在tomcat运行的时候显示不了修改后的痕迹。这个时候删除work目录下对应的项目文件夹,重新启动tomcat就可以了。

转载于:https://www.cnblogs.com/canger/p/8310042.html

### 回答1: java.io.EOFException: zlib输入流意外结束 这个错误通常是由于读取zlib压缩数据时出现问题导致的。可能是数据损坏或不完整,也可能是读取器没有正确处理数据。建议检查数据源和读取器的代码,以确保它们正确处理数据。 ### 回答2: Java中,当使用Zlib解压缩流时,如果出现异常java.io.eofexception: unexpected end of zlib input stream,将会导致解压缩失败。EOF表示文件已经到了结尾,而该错误的出现原因是Zlib流没有按照正确的规则结束。这意味着压缩数据中存在一些错误或损坏,从而导致解码失败。 该异常可能由许多原因引起,如文件损坏、网络错误、流不完整、缺少字节等等。因此,我们需要在代码实现中遵循以下建议,来避免或解决该异常: 1.进行数据完整性检查:在使用Zlib解压缩流之前,我们需要确保所读取的压缩数据是完整的。我们可以在读取数据时,添加一些数据完整性检查的代码,以确保数据的完整性,从而避免解压缩失败。 2.处理异常:当该异常发生时,我们需要注意及时处理异常,以避免程序崩溃。我们可以使用try-catch语句,来捕获该异常并进行相应的处理。例如,我们可以输出错误信息,以帮助我们更好地理解问题。 3.检查是否在压缩和解压缩时使用相同的设置:在使用Zlib进行压缩和解压缩时,我们需要确保使用相同的设置。如果两次设置不同,可能会导致无法正确解压缩数据,从而引发该异常。 4.检查压缩数据:有时候,该异常是由于压缩数据本身出现了错误或损坏而导致的。因此,在使用Zlib解压缩流时,我们需要仔细检查所有的压缩数据,以确定是否存在任何问题。 总的来说,java.io.eofexception: unexpected end of zlib input stream异常是在进行Zlib解压缩流时可能会出现的问题。我们需要熟悉Java中的Zlib库及其应用场景,同时也需要在代码实现中遵循上述建议,以避免该异常的出现,从而保证程序的正常运行。 ### 回答3: Java中的EOFException是指在输入流中没有更多的数据可供读取的情况下,尝试读取数据时会抛出的异常。而当出现"unexpected end of zlib input stream"的异常时,表示zlib输入流在解压时遇到了意料之外的流结束标志,通常是由于文件或网络数据传输过程中被截断或损坏导致。 具体地说,这个异常通常会在使用Java中的GZIPInputStream、InflaterInputStream、Inflater等压缩解压缩相关API进行数据读取时出现。当在读取时遇到了意料之外的数据结尾标志,就会抛出异常中提到的这个错误信息。 要解决这个问题,首先需要确保数据源或文件本身没有被损坏或截断。如果数据源没有问题,那么很可能是程序在使用压缩解压缩API时的问题,可能需要检查调用API时的参数、输入流和输出流的正确性,或者尝试使用其他的API进行处理。 另外,如果是在网络传输过程中出现问题,可以考虑使用文件传输协议,例如FTP或SFTP,在传输文件时自动进行校验,以保证传输的安全性和完整性。另外,也可以使用一些数据压缩和加密的工具,例如JZlib、Bouncy Castle等,对数据进行保护和处理,从而避免出现类似的异常
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值