解决IntelliJ IDEA报错Failed to read candidate component class: file [ ]; nested exception is org.

约定不等于承诺〃 2021-09-25 07:52 553阅读 0赞

解决IntelliJ IDEA报错Failed to read candidate component class: file [ ]; nested exception is org.springframework.core.NestedIOException

  笔者使用 IntelliJ IDEA 运行以前的一个 Spring 项目时,以前记得运行正常的代码,如今一直报错,百思不得其解。然后发现报错发生在一个普通、基础性的 Spring 方法。笔者当时报错时的运行环境如下:

笔者报错时的运行环境:

JDK 13.0.2

IntelliJ IDEA 2020.1.2 (Ultimate Edition)

Spring 5.1.9.RELEASE

  这个报错的信息如下:

  1. Exception in thread "XXX" org.springframework.beans.factory.BeanDefinitionStoreException: Failed to read candidate component class: file [XXX.class]; nested exception is org.springframework.core.NestedIOException: ASM ClassReader failed to parse class file - probably due to a new Java class file version that isn't supported yet: file [XXX.class]; nested exception is java.lang.IllegalArgumentException: Unsupported class file major version 57
  2. at org.springframework.context.annotation.ClassPathScanningCandidateComponentProvider.scanCandidateComponents(ClassPathScanningCandidateComponentProvider.java:454)
  3. at org.springframework.context.annotation.ClassPathScanningCandidateComponentProvider.findCandidateComponents(ClassPathScanningCandidateComponentProvider.java:316)
  4. at org.springframework.context.annotation.ClassPathBeanDefinitionScanner.doScan(ClassPathBeanDefinitionScanner.java:275)
  5. at org.springframework.context.annotation.ComponentScanBeanDefinitionParser.parse(ComponentScanBeanDefinitionParser.java:90)
  6. at org.springframework.beans.factory.xml.NamespaceHandlerSupport.parse(NamespaceHandlerSupport.java:74)
  7. at org.springframework.beans.factory.xml.BeanDefinitionParserDelegate.parseCustomElement(BeanDefinitionParserDelegate.java:1391)
  8. at org.springframework.beans.factory.xml.BeanDefinitionParserDelegate.parseCustomElement(BeanDefinitionParserDelegate.java:1371)
  9. at org.springframework.beans.factory.xml.DefaultBeanDefinitionDocumentReader.parseBeanDefinitions(DefaultBeanDefinitionDocumentReader.java:179)
  10. at org.springframework.beans.factory.xml.DefaultBeanDefinitionDocumentReader.doRegisterBeanDefinitions(DefaultBeanDefinitionDocumentReader.java:149)
  11. at org.springframework.beans.factory.xml.DefaultBeanDefinitionDocumentReader.registerBeanDefinitions(DefaultBeanDefinitionDocumentReader.java:96)
  12. at org.springframework.beans.factory.xml.XmlBeanDefinitionReader.registerBeanDefinitions(XmlBeanDefinitionReader.java:513)
  13. at org.springframework.beans.factory.xml.XmlBeanDefinitionReader.doLoadBeanDefinitions(XmlBeanDefinitionReader.java:393)
  14. at org.springframework.beans.factory.xml.XmlBeanDefinitionReader.loadBeanDefinitions(XmlBeanDefinitionReader.java:336)
  15. at org.springframework.beans.factory.xml.XmlBeanDefinitionReader.loadBeanDefinitions(XmlBeanDefinitionReader.java:304)
  16. at org.springframework.beans.factory.support.AbstractBeanDefinitionReader.loadBeanDefinitions(AbstractBeanDefinitionReader.java:188)
  17. at org.springframework.beans.factory.support.AbstractBeanDefinitionReader.loadBeanDefinitions(AbstractBeanDefinitionReader.java:224)
  18. at org.springframework.beans.factory.support.AbstractBeanDefinitionReader.loadBeanDefinitions(AbstractBeanDefinitionReader.java:195)
  19. at org.springframework.beans.factory.support.AbstractBeanDefinitionReader.loadBeanDefinitions(AbstractBeanDefinitionReader.java:257)
  20. at org.springframework.context.support.AbstractXmlApplicationContext.loadBeanDefinitions(AbstractXmlApplicationContext.java:128)
  21. at org.springframework.context.support.AbstractXmlApplicationContext.loadBeanDefinitions(AbstractXmlApplicationContext.java:94)
  22. at org.springframework.context.support.AbstractRefreshableApplicationContext.refreshBeanFactory(AbstractRefreshableApplicationContext.java:133)
  23. at org.springframework.context.support.AbstractApplicationContext.obtainFreshBeanFactory(AbstractApplicationContext.java:636)
  24. at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:521)
  25. at org.springframework.context.support.ClassPathXmlApplicationContext.<init>(ClassPathXmlApplicationContext.java:144)
  26. at org.springframework.context.support.ClassPathXmlApplicationContext.<init>(ClassPathXmlApplicationContext.java:85)
  27. at XXX(XXX:XXX)
  28. Caused by: org.springframework.core.NestedIOException: ASM ClassReader failed to parse class file - probably due to a new Java class file version that isn't supported yet: file [XXX.class]; nested exception is java.lang.IllegalArgumentException: Unsupported class file major version 57
  29. at org.springframework.core.type.classreading.SimpleMetadataReader.<init>(SimpleMetadataReader.java:57)
  30. at org.springframework.core.type.classreading.SimpleMetadataReaderFactory.getMetadataReader(SimpleMetadataReaderFactory.java:103)
  31. at org.springframework.core.type.classreading.CachingMetadataReaderFactory.getMetadataReader(CachingMetadataReaderFactory.java:123)
  32. at org.springframework.context.annotation.ClassPathScanningCandidateComponentProvider.scanCandidateComponents(ClassPathScanningCandidateComponentProvider.java:430)
  33. ... 25 more
  34. Caused by: java.lang.IllegalArgumentException: Unsupported class file major version 57
  35. at org.springframework.asm.ClassReader.<init>(ClassReader.java:184)
  36. at org.springframework.asm.ClassReader.<init>(ClassReader.java:166)
  37. at org.springframework.asm.ClassReader.<init>(ClassReader.java:152)
  38. at org.springframework.asm.ClassReader.<init>(ClassReader.java:273)
  39. at org.springframework.core.type.classreading.SimpleMetadataReader.<init>(SimpleMetadataReader.java:54)
  40. ... 28 more

  笔者在经过反复试验排错后,终于找到了根因。这是因为笔者报错时,使用的 Spring 依赖与 JDK 版本不兼容所导致的。因为笔者当初成功运行该项目时,使用的是低版本的 JDK,而现在运行该项目时,使用的是现在安装的 JDK。换句话说,相对于 Spring 的版本Spring 5.1.9.RELEASE,JDK 的版本JDK 13.0.2太高了。

  于是,笔者调高 Spring 的版本,将Spring 5.1.9.RELEASE改为Spring 5.2.9.RELEASE,结果运行之后,上面的报错就消失了。当然,也可以选择降低 JDK 的版本,不过笔者通常不喜欢这样做。

笔者成功运行时的运行环境:

JDK 13.0.2

IntelliJ IDEA 2020.1.2 (Ultimate Edition)

Spring 5.2.9.RELEASE

发表评论

表情:
评论列表 (有 0 条评论,553人围观)

还没有评论,来说两句吧...

相关阅读