1. 程式人生 > >運行Maven項目時出現invalid LOC header (bad signature)錯誤,Tomcat不能正常啟動

運行Maven項目時出現invalid LOC header (bad signature)錯誤,Tomcat不能正常啟動

argument 不能 sig 嚴重 對話 toc cau ebr tom

作為Maven小白,今天這問題困擾了我好久,經過多次在網上查詢,終於找到了原因。明明一個小問題卻耗費很多時間,著實不應該,所以必須記錄一下。

報錯信息如下:

對話框:

技術分享圖片

控制臺:

[html] view plain copy
  1. <span style="font-size:14px;"><span style="color:#ff0000;">嚴重: A child container failed during start
  2. java.util.concurrent.ExecutionException: org.apache.catalina.LifecycleException: Failed to start component [StandardEngine[Catalina].StandardHost[localhost].StandardContext[/SpringMvcController]]
  3. at java.util.concurrent.FutureTask.report(Unknown Source)
  4. at java.util.concurrent.FutureTask.get(Unknown Source)
  5. at org.apache.catalina.core.ContainerBase.startInternal(ContainerBase.java:916)
  6. at org.apache.catalina.core.StandardHost.startInternal(StandardHost.java:871)
  7. at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150)
  8. at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1408)
  9. at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1398)
  10. at java.util.concurrent.FutureTask.run(Unknown Source)
  11. at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source)
  12. at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)
  13. at java.lang.Thread.run(Unknown Source)
  14. Caused by: org.apache.catalina.LifecycleException: Failed to start component [StandardEngine[Catalina].StandardHost[localhost].StandardContext[/SpringMvcController]]
  15. at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:154)
  16. ... 6 more
  17. Caused by: org.apache.catalina.LifecycleException: Failed to start component [org.apache.catalina.webresources.StandardRoot@43cd5898]
  18. at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:154)
  19. at org.apache.catalina.core.StandardContext.resourcesStart(StandardContext.java:4909)
  20. at org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5039)
  21. at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150)
  22. ... 6 more
  23. Caused by: org.apache.catalina.LifecycleException: Failed to initialize component [org.apache.catalina.webresources.JarResourceSet@4d31c0af]
  24. at org.apache.catalina.util.LifecycleBase.init(LifecycleBase.java:106)
  25. at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:139)
  26. at org.apache.catalina.webresources.StandardRoot.startInternal(StandardRoot.java:699)
  27. at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150)
  28. ... 9 more
  29. Caused by: java.lang.IllegalArgumentException: java.util.zip.ZipException: invalid LOC header (bad signature)
  30. at org.apache.catalina.webresources.JarResourceSet.initInternal(JarResourceSet.java:96)
  31. at org.apache.catalina.util.LifecycleBase.init(LifecycleBase.java:102)
  32. ... 12 more
  33. Caused by: java.util.zip.ZipException: invalid LOC header (bad signature)
  34. at java.util.zip.ZipFile.read(Native Method)
  35. at java.util.zip.ZipFile.access$1400(Unknown Source)
  36. at java.util.zip.ZipFile$ZipFileInputStream.read(Unknown Source)
  37. at java.util.zip.ZipFile$ZipFileInflaterInputStream.fill(Unknown Source)
  38. at java.util.zip.InflaterInputStream.read(Unknown Source)
  39. at sun.misc.IOUtils.readFully(Unknown Source)
  40. at java.util.jar.JarFile.getBytes(Unknown Source)
  41. at java.util.jar.JarFile.getManifestFromReference(Unknown Source)
  42. at java.util.jar.JarFile.getManifest(Unknown Source)
  43. at org.apache.catalina.webresources.JarResourceSet.initInternal(JarResourceSet.java:94)
  44. ... 13 more
  45. 十一月 29, 2016 2:54:19 下午 org.apache.catalina.core.ContainerBase startInternal
  46. 嚴重: A child container failed during start
  47. java.util.concurrent.ExecutionException: org.apache.catalina.LifecycleException: Failed to start component [StandardEngine[Catalina].StandardHost[localhost]]
  48. at java.util.concurrent.FutureTask.report(Unknown Source)
  49. at java.util.concurrent.FutureTask.get(Unknown Source)
  50. at org.apache.catalina.core.ContainerBase.startInternal(ContainerBase.java:916)
  51. at org.apache.catalina.core.StandardEngine.startInternal(StandardEngine.java:262)
  52. at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150)
  53. at org.apache.catalina.core.StandardService.startInternal(StandardService.java:439)
  54. at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150)
  55. at org.apache.catalina.core.StandardServer.startInternal(StandardServer.java:769)
  56. at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150)
  57. at org.apache.catalina.startup.Catalina.start(Catalina.java:625)
  58. at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
  59. at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
  60. at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
  61. at java.lang.reflect.Method.invoke(Unknown Source)
  62. at org.apache.catalina.startup.Bootstrap.start(Bootstrap.java:351)
  63. at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:485)
  64. Caused by: org.apache.catalina.LifecycleException: Failed to start component [StandardEngine[Catalina].StandardHost[localhost]]
  65. at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:154)
  66. at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1408)
  67. at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1398)
  68. at java.util.concurrent.FutureTask.run(Unknown Source)
  69. at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source)
  70. at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)
  71. at java.lang.Thread.run(Unknown Source)
  72. Caused by: org.apache.catalina.LifecycleException: A child container failed during start
  73. at org.apache.catalina.core.ContainerBase.startInternal(ContainerBase.java:924)
  74. at org.apache.catalina.core.StandardHost.startInternal(StandardHost.java:871)
  75. at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150)
  76. ... 6 more
  77. 十一月 29, 2016 2:54:19 下午 org.apache.catalina.startup.Catalina start
  78. 嚴重: The required Server component failed to start so Tomcat is unable to start.
  79. org.apache.catalina.LifecycleException: Failed to start component [StandardServer[8005]]
  80. at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:154)
  81. at org.apache.catalina.startup.Catalina.start(Catalina.java:625)
  82. at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
  83. at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
  84. at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
  85. at java.lang.reflect.Method.invoke(Unknown Source)
  86. at org.apache.catalina.startup.Bootstrap.start(Bootstrap.java:351)
  87. at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:485)
  88. Caused by: org.apache.catalina.LifecycleException: Failed to start component [StandardService[Catalina]]
  89. at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:154)
  90. at org.apache.catalina.core.StandardServer.startInternal(StandardServer.java:769)
  91. at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150)
  92. ... 7 more
  93. Caused by: org.apache.catalina.LifecycleException: Failed to start component [StandardEngine[Catalina]]
  94. at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:154)
  95. at org.apache.catalina.core.StandardService.startInternal(StandardService.java:439)
  96. at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150)
  97. ... 9 more
  98. Caused by: org.apache.catalina.LifecycleException: A child container failed during start
  99. at org.apache.catalina.core.ContainerBase.startInternal(ContainerBase.java:924)
  100. at org.apache.catalina.core.StandardEngine.startInternal(StandardEngine.java:262)
  101. at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150)
  102. ... 11 more
  103. 十一月 29, 2016 2:54:19 下午 org.apache.coyote.AbstractProtocol pause
  104. 信息: Pausing ProtocolHandler ["http-nio-8080"]
  105. 十一月 29, 2016 2:54:19 下午 org.apache.coyote.AbstractProtocol pause
  106. 信息: Pausing ProtocolHandler ["ajp-nio-8009"]
  107. 十一月 29, 2016 2:54:19 下午 org.apache.catalina.core.StandardService stopInternal
  108. 信息: Stopping service Catalina
  109. 十一月 29, 2016 2:54:19 下午 org.apache.coyote.AbstractProtocol destroy
  110. 信息: Destroying ProtocolHandler ["http-nio-8080"]
  111. 十一月 29, 2016 2:54:19 下午 org.apache.coyote.AbstractProtocol destroy
  112. 嚴重: Failed to destroy end point associated with ProtocolHandler ["http-nio-8080"]
  113. java.lang.NullPointerException
  114. at org.apache.tomcat.util.net.NioEndpoint.releaseCaches(NioEndpoint.java:305)
  115. at org.apache.tomcat.util.net.NioEndpoint.unbind(NioEndpoint.java:481)
  116. at org.apache.tomcat.util.net.AbstractEndpoint.destroy(AbstractEndpoint.java:823)
  117. at org.apache.coyote.AbstractProtocol.destroy(AbstractProtocol.java:533)
  118. at org.apache.catalina.connector.Connector.destroyInternal(Connector.java:1023)
  119. at org.apache.catalina.util.LifecycleBase.destroy(LifecycleBase.java:305)
  120. at org.apache.catalina.core.StandardService.destroyInternal(StandardService.java:588)
  121. at org.apache.catalina.util.LifecycleBase.destroy(LifecycleBase.java:305)
  122. at org.apache.catalina.core.StandardServer.destroyInternal(StandardServer.java:859)
  123. at org.apache.catalina.util.LifecycleBase.destroy(LifecycleBase.java:305)
  124. at org.apache.catalina.startup.Catalina.start(Catalina.java:629)
  125. at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
  126. at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
  127. at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
  128. at java.lang.reflect.Method.invoke(Unknown Source)
  129. at org.apache.catalina.startup.Bootstrap.start(Bootstrap.java:351)
  130. at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:485)
  131. 十一月 29, 2016 2:54:19 下午 org.apache.coyote.AbstractProtocol destroy
  132. 信息: Destroying ProtocolHandler ["ajp-nio-8009"]
  133. 十一月 29, 2016 2:54:19 下午 org.apache.coyote.AbstractProtocol destroy
  134. 嚴重: Failed to destroy end point associated with ProtocolHandler ["ajp-nio-8009"]
  135. java.lang.NullPointerException
  136. at org.apache.tomcat.util.net.NioEndpoint.releaseCaches(NioEndpoint.java:305)
  137. at org.apache.tomcat.util.net.NioEndpoint.unbind(NioEndpoint.java:481)
  138. at org.apache.tomcat.util.net.AbstractEndpoint.destroy(AbstractEndpoint.java:823)
  139. at org.apache.coyote.AbstractProtocol.destroy(AbstractProtocol.java:533)
  140. at org.apache.catalina.connector.Connector.destroyInternal(Connector.java:1023)
  141. at org.apache.catalina.util.LifecycleBase.destroy(LifecycleBase.java:305)
  142. at org.apache.catalina.core.StandardService.destroyInternal(StandardService.java:588)
  143. at org.apache.catalina.util.LifecycleBase.destroy(LifecycleBase.java:305)
  144. at org.apache.catalina.core.StandardServer.destroyInternal(StandardServer.java:859)
  145. at org.apache.catalina.util.LifecycleBase.destroy(LifecycleBase.java:305)
  146. at org.apache.catalina.startup.Catalina.start(Catalina.java:629)
  147. at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
  148. at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
  149. at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
  150. at java.lang.reflect.Method.invoke(Unknown Source)
  151. at org.apache.catalina.startup.Bootstrap.start(Bootstrap.java:351)
  152. at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:485)</span>
  153. </span>

原因:

提取錯誤的關鍵信息

技術分享圖片

說明Jar包出現了問題。

那麽接下來就要找哪個jar包出現了問題:

方法1、可通過右擊項目名 -> Run as -> Maven test ,這時控制臺會報哪個jar包出錯。 (也可以打開DOS命令窗口,切換至項目目錄,運行mvn test命令,和Eclipse的控制臺輸出信息一致)

方法2、如果方法1未出現任何錯誤信息,那麽就使用笨辦法。打開項目中的pom.xml文件,在自己的Maven本地倉庫去查找pom.xml文件中每一個dependency節點所對應的jar包版本。一個一個對比,看看是否都正常下載。

這裏,我找到了本地倉庫中出現的jar包錯誤:

技術分享圖片

解決方法:

既然jar包未下載成功,那麽重新下載就行了。如果重新下載還是不能成功,那就在網上下載同版本的拷貝進去。

刪除掉該jar包所在目錄下的所有文件後,重新運行maven install。

技術分享圖片

這時,可看到jar包已正常下載。

技術分享圖片

再次運行項目,右擊項目 -> Run as -> Run on server 。可以發現,項目能正常運行了。

運行Maven項目時出現invalid LOC header (bad signature)錯誤,Tomcat不能正常啟動