web-dev-qa-db-fra.com

L'initialisation du contexte de printemps a échoué avec une exception Java.lang.IllegalArgumentException lors du déploiement sur Apache 7.0.54 et Java 8

Environnement: Serveur d’application: Apache 7.0.54Java: "1.8.0_05" OS: Mac OS X 10.9.3

Bibliothèques: application Spring 3.2 REST

Voici l'erreur que j'ai reçue lors du déploiement:

localhost.2014.06.09.log

Jun 09, 2014 3:37:47 PM org.Apache.catalina.core.ApplicationContext log
INFO: No Spring WebApplicationInitializer types detected on classpath
Jun 09, 2014 3:37:47 PM org.Apache.catalina.core.ApplicationContext log
INFO: Initializing Spring root WebApplicationContext
Jun 09, 2014 3:37:47 PM org.Apache.catalina.core.StandardContext listenerStart
SEVERE: Exception sending context initialized event to listener instance of class org.springframework.web.context.ContextLoaderListener

Java.lang.IllegalArgumentException
    at org.springframework.asm.ClassReader.<init>(Unknown Source)
    at org.springframework.asm.ClassReader.<init>(Unknown Source)
    at org.springframework.asm.ClassReader.<init>(Unknown Source)
    at org.springframework.core.type.classreading.SimpleMetadataReader.<init>(SimpleMetadataReader.Java:52)
    at org.springframework.core.type.classreading.SimpleMetadataReaderFactory.getMetadataReader(SimpleMetadataReaderFactory.Java:80)
    at org.springframework.core.type.classreading.CachingMetadataReaderFactory.getMetadataReader(CachingMetadataReaderFactory.Java:101)
    at org.springframework.core.type.classreading.SimpleMetadataReaderFactory.getMetadataReader(SimpleMetadataReaderFactory.Java:76)
    at org.springframework.context.annotation.ConfigurationClassParser.getImports(ConfigurationClassParser.Java:298)
    at org.springframework.context.annotation.ConfigurationClassParser.getImports(ConfigurationClassParser.Java:300)
    at org.springframework.context.annotation.ConfigurationClassParser.getImports(ConfigurationClassParser.Java:300)
    at org.springframework.context.annotation.ConfigurationClassParser.doProcessConfigurationClass(ConfigurationClassParser.Java:230)
    at org.springframework.context.annotation.ConfigurationClassParser.processConfigurationClass(ConfigurationClassParser.Java:153)
    at org.springframework.context.annotation.ConfigurationClassParser.parse(ConfigurationClassParser.Java:130)
    at org.springframework.context.annotation.ConfigurationClassPostProcessor.processConfigBeanDefinitions(ConfigurationClassPostProcessor.Java:285)
    at org.springframework.context.annotation.ConfigurationClassPostProcessor.postProcessBeanDefinitionRegistry(ConfigurationClassPostProcessor.Java:223)
    at org.springframework.context.support.AbstractApplicationContext.invokeBeanFactoryPostProcessors(AbstractApplicationContext.Java:630)
    at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.Java:461)
    at org.springframework.web.context.ContextLoader.configureAndRefreshWebApplicationContext(ContextLoader.Java:383)
    at org.springframework.web.context.ContextLoader.initWebApplicationContext(ContextLoader.Java:283)
    at org.springframework.web.context.ContextLoaderListener.contextInitialized(ContextLoaderListener.Java:112)
    at org.Apache.catalina.core.StandardContext.listenerStart(StandardContext.Java:4973)
    at org.Apache.catalina.core.StandardContext.startInternal(StandardContext.Java:5467)
    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:632)
    at org.Apache.catalina.startup.HostConfig.deployWAR(HostConfig.Java:1083)
    at org.Apache.catalina.startup.HostConfig$DeployWar.run(HostConfig.Java:1880)
    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:1142)
    at Java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.Java:617)
    at Java.lang.Thread.run(Thread.Java:745)
40
user827096

Vous devez mettre à niveau vers la version Spring 4 pour prendre en charge le format de code Java 1.8 octets. 

68
Jigar Joshi

Si vous ne pouvez pas y aller, Spring 4 suffit de passer à la version 3.2.16 pour résoudre le problème.

Merci à Tom Saleeba

19
Aalkhodiry

Dans mon cas, mon application fonctionne avec Java8 et Jetty, utilise Spring 3.1.4 et ne peut pas être mise à niveau.

Le problème est apparu après l'utilisation d'une fonction lambda dans une définition de haricot. Le supprimer a résolu mon problème.

0
riccardo.tasso

Le passage au printemps 3.2.16 a résolu le problème. Ressemble à l'ancienne version de printemps n'aime pas Java 1.8.xxx

0
Parik Chudasma