Invalid byte tag in constant pool: 19

一、问题

Invalid byte tag in constant pool: 19

具体错误:

org.apache.catalina.startup.ContextConfig.processAnnotationsJar Unable to process Jar entry [META-INF/versions/9/module-info.class] from Jar [file:/G:/Tomcat/webapps/blog/WEB-INF/lib/bcprov-jdk15on-1.64.jar] for annotations

二、问题分析

Tomcat报此错误明显的是加载依赖的jar导致的问题,具体到项目的哪个jar就是上面的具体错误,本项目是bcprov-jdk15on-1.64.jar导致的问题,更具体的是无法加载 [META-INF/versions/9/module-info.class] 字节码文件。
其实,即使是其他的jar也可能会导致Tomcat出现Invalid byte tag in constant pool: 19的问题。

三、问题解决

搜索了一下网页,大多都是说jar包没有用到,直接删除;甚至是修改Tomcat启动命令跳过该jar。
但是,项目确实用到了该jar包删除或者跳过加载显然不合适,最好的办法就是分析自己的错误,真正找到解决办法。
本项目bcprov-jdk15on-1.64.jar导致的问题,找到jar解压文件,清单文件下的META-INF/versions/9/module-info.class确实存在。第三方的jar我们没有办法修改,怎么办?只能查看其他版本试试或者降低到没有module-info.class文件的版本。
最终发现,1.60版本没有此class文件,1.61开始添加了此文件,于是降低版本修改依赖版本为1.60,问题解决!

发布了32 篇原创文章 · 获赞 10 · 访问量 2万+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章