完美解决tomcat启动异常:Invalid byte tag in constant pool: 19;Unable to process Jar entry [module-info.class]

简介: 完美解决tomcat启动异常:Invalid byte tag in constant pool: 19;Unable to process Jar entry [module-info.class]

1、现象描述

tomcat启动,控制台有异常信息,具体如下:

24-Oct-2023 09:28:59.128 INFO [localhost-startStop-1] org.apache.catalina.startup.HostConfig.deployWAR Deploying web application archive /opt/hidata/tomcat8.5-db2-patrol/webapps/hijob-ansible.war
24-Oct-2023 09:29:01.251 SEVERE [localhost-startStop-1] org.apache.catalina.startup.ContextConfig.processAnnotationsJar Unable to process Jar entry [module-info.class] from Jar [file:/opt/hidata/tomcat8.5-db2-patrol/webapps/hijob-ansible/WEB-INF/lib/gson-2.8.6.jar] for annotations
 org.apache.tomcat.util.bcel.classfile.ClassFormatException: Invalid byte tag in constant pool: 19
  at org.apache.tomcat.util.bcel.classfile.Constant.readConstant(Constant.java:97)
  at org.apache.tomcat.util.bcel.classfile.ConstantPool.<init>(ConstantPool.java:54)
  at org.apache.tomcat.util.bcel.classfile.ClassParser.readConstantPool(ClassParser.java:174)
  at org.apache.tomcat.util.bcel.classfile.ClassParser.parse(ClassParser.java:83)
  at org.apache.catalina.startup.ContextConfig.processAnnotationsStream(ContextConfig.java:2053)
  at org.apache.catalina.startup.ContextConfig.processAnnotationsJar(ContextConfig.java:2000)
  at org.apache.catalina.startup.ContextConfig.processAnnotationsUrl(ContextConfig.java:1970)
  at org.apache.catalina.startup.ContextConfig.processAnnotations(ContextConfig.java:1923)
  at org.apache.catalina.startup.ContextConfig.webConfig(ContextConfig.java:1163)
  at org.apache.catalina.startup.ContextConfig.configureStart(ContextConfig.java:775)
  at org.apache.catalina.startup.ContextConfig.lifecycleEvent(ContextConfig.java:299)
  at org.apache.catalina.util.LifecycleBase.fireLifecycleEvent(LifecycleBase.java:94)
  at org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5087)
  at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150)
  at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:752)
  at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:728)
  at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:734)
  at org.apache.catalina.startup.HostConfig.deployWAR(HostConfig.java:952)
  at org.apache.catalina.startup.HostConfig$DeployWar.run(HostConfig.java:1823)
  at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:511)
  at java.util.concurrent.FutureTask.run(FutureTask.java:266)
  at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)
  at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
  at java.lang.Thread.run(Thread.java:748)

2、分析原因

异常日志中,比较关键的日志信息是这两句:

Invalid byte tag in constant pool: 19
org.apache.catalina.startup.ContextConfig.processAnnotationsJar Unable to process Jar entry [module-info.class] from Jar 
[file:/opt/hidata/tomcat8.5-db2-patrol/webapps/hijob-ansible/WEB-INF/lib/gson-2.8.6.jar] for annotations

项目中使用的tomcat版本是8.5版本,经过查询,发现异常信息是说 tomcat无法解析 gson-2.8.6.jar这个包,因为这个jar包里面使用到了jdk1.9的语法。

3、解决方案

有两种解决方案

  • (1)将tomcat的版本升级到9
  • (2)修改tomcat8.5版本的配置文件

(1)方案一 :将tomcat的版本升级到9

直接把tomcat8.5版本换成tomcat9版本即可,亲测有效。

细节:在启动Tomcat9时,控制台可能会出现IllegalArgumentException异常,即“AJP连接器配置secretRequired=“true”,但是属性secret确实空或者空字符串,这样的组合是无效的。”或者

The AJP Connector is configured with secretRequired="true" but the secret 

原因是因为tomcat的配置文件server.xml里面,没有配置 secretRequired 这个属性,我们打开server.xml,tomcat9默认的配置是这样的

<Connector protocol="AJP/1.3"
           address="::1"
           port="8009"
           redirectPort="8443" 
           />

现在需要加上 secretRequired 这个属性。可以不用赋值,直接给个空字符串

<Connector protocol="AJP/1.3"
           address="::1"
           port="8009"
           redirectPort="8443"
           secretRequired="" 
           />

这样,再次启动就不会再报错了

(2)方案二 :修改tomcat8.5版本的配置文件

这个解决办法比较方便,不需要换tomcat,直接修改配置文件。

到tomcat的conf目录下,打开catalina.properties文件,找到 tomcat.util.scan.StandardJarScanFilter.jarsToSkip 这句话

然后,把我们刚刚报错的那个jar包,直接添加到后面就可以了。看日志是说gson-2.8.6.jar这个包,那我们就加他,

这个方式也同样可以解决这个异常

相关文章
|
8月前
|
Java 应用服务中间件
程序启动时报: Invalid byte tag in constant pool: 19
程序启动时报: Invalid byte tag in constant pool: 19
425 0
|
6月前
|
Java 应用服务中间件
tomcat7 与 tomcat8 加载 jar包的顺序
tomcat7 与 tomcat8 加载 jar包的顺序
221 0
|
6月前
|
编解码 程序员 开发者
【Python】已解决:UnicodeDecodeError: ‘utf-8’ codec can’t decode byte 0xa1 in position 0: invalid start by
【Python】已解决:UnicodeDecodeError: ‘utf-8’ codec can’t decode byte 0xa1 in position 0: invalid start by
6411 0
|
8月前
|
Java 应用服务中间件
解决tomcat启动报错:无法在web.xml或使用此应用程序部署的jar文件中解析绝对的url [http:java.sun.com/jsp/jstl/core]
解决tomcat启动报错:无法在web.xml或使用此应用程序部署的jar文件中解析绝对的url [http:java.sun.com/jsp/jstl/core]
1714 1
|
8月前
|
Oracle 关系型数据库 Java
Flink CDC产品常见问题之Flink CDC 使用jar包启动异常如何解决
Flink CDC(Change Data Capture)是一个基于Apache Flink的实时数据变更捕获库,用于实现数据库的实时同步和变更流的处理;在本汇总中,我们组织了关于Flink CDC产品在实践中用户经常提出的问题及其解答,目的是辅助用户更好地理解和应用这一技术,优化实时数据处理流程。
|
8月前
|
Java Maven
maven管理工具使用package打包的时候无法将lib文件夹下的第三方jar包打入,上线打jar包后运行异常问题
maven管理工具使用package打包的时候无法将lib文件夹下的第三方jar包打入,上线打jar包后运行异常问题
|
6月前
|
Java
[JarEditor]可直接修改jar包的IDEA插件
### 修改JAR包变得更简单:JarEditor插件简介 **背景:** 开发中常需修改JAR包中的class文件,传统方法耗时费力。JarEditor插件让你一键编辑JAR包内文件,无需解压。 **插件使用:** 1. **安装:** 在IDEA插件市场搜索JarEditor并安装。 2. **修改class:** 打开JAR文件中的class,直接编辑,保存后一键构建更新JAR。 3. **文件管理:** 右键菜单支持在JAR内新增/删除/重命名文件等操作。 4. **搜索:** 使用内置搜索功能快速定位JAR包内的字符串。
601 2
[JarEditor]可直接修改jar包的IDEA插件
|
6月前
|
弹性计算 Java Serverless
Serverless 应用引擎操作报错合集之上传自定义JAR包,启动时报错,是什么导致的
Serverless 应用引擎(SAE)是阿里云提供的Serverless PaaS平台,支持Spring Cloud、Dubbo、HSF等主流微服务框架,简化应用的部署、运维和弹性伸缩。在使用SAE过程中,可能会遇到各种操作报错。以下是一些常见的报错情况及其可能的原因和解决方法。
|
6月前
|
关系型数据库 Java 分布式数据库
PolarDB产品使用问题之部署到服务器上的Java应用(以jar包形式运行)无法连接,如何解决
PolarDB产品使用合集涵盖了从创建与管理、数据管理、性能优化与诊断、安全与合规到生态与集成、运维与支持等全方位的功能和服务,旨在帮助企业轻松构建高可用、高性能且易于管理的数据库环境,满足不同业务场景的需求。用户可以通过阿里云控制台、API、SDK等方式便捷地使用这些功能,实现数据库的高效运维与持续优化。