2010-05-12 8 views
1

J'ai 2 projets Maven mis en place comme ceci:Maven/Spring/Java: ClassNotFoundException - mais je sais que la classe est là

-com.wuntee.rsaAuthenticationManager (jar) 

-com.wuntee.taac (pom) 
--taac-backend-gui (jar) 
--taac-web (war) 

Et 'com.wuntee.rsaAuthenticationManager' est un dep dans 'taac-backend-gui'. Lors de l'exécution d'un cas de test dans taac-backend-gui, tout s'exécute correctement, mais lorsque j'essaie de démarrer le taac-web, j'obtiens le ClassNotFoundException suivant - la bibliothèque qui contient la classe 'weblogic.security.SSL.TrustManager' est également dans mon référentiel maven local, et défini en tant que dépendance de com.wuntee.rsaAuthenticationManager. Est-ce que quelqu'un sait pourquoi je recevrais cette erreur? J'ai également essayé d'ajouter directement la bibliothèque contenant TrustManager au projet taac-web, tout en obtenant la même exception. Des idées?

ERROR[com.wuntee.taac.business.TaacWorkshop][main] - couldnt create rsa dao: 
com.rsa.common.SystemException: Command target (CommandAPIConnection) initialization failure 
    java.lang.NoClassDefFoundError: weblogic/security/SSL/TrustManager 
    at com.rsa.command.ConnectionFactory.getSpringBeanTarget(ConnectionFactory.java:212) 
    at com.rsa.command.ConnectionFactory.getTarget(ConnectionFactory.java:170) 
    at com.rsa.command.ConnectionFactory.getConnection(ConnectionFactory.java:246) 
    at com.wuntee.rsaAuthenticationManager.RsaAuthenticationManagerDao.init(RsaAuthenticationManagerDao.java:60) 
    at com.wuntee.taac.business.TaacWorkshop.<init>(TaacWorkshop.java:68) 
    at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method) 
    at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:39) 
    at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:27) 
    at java.lang.reflect.Constructor.newInstance(Constructor.java:501) 
    at org.springframework.beans.BeanUtils.instantiateClass(BeanUtils.java:126) 
    at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:72) 
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.instantiateBean(AbstractAutowireCapableBeanFactory.java:939) 
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBeanInstance(AbstractAutowireCapableBeanFactory.java:892) 
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:479) 
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:450) 
    at org.springframework.beans.factory.support.AbstractBeanFactory$1.getObject(AbstractBeanFactory.java:290) 
    at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:222) 
    at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:287) 
    at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:189) 
    at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:562) 
    at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:871) 
    at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:423) 
    at org.springframework.web.context.ContextLoader.createWebApplicationContext(ContextLoader.java:272) 
    at org.springframework.web.context.ContextLoader.initWebApplicationContext(ContextLoader.java:196) 
    at org.springframework.web.context.ContextLoaderListener.contextInitialized(ContextLoaderListener.java:47) 
    at org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java:3972) 
    at org.apache.catalina.core.StandardContext.start(StandardContext.java:4467) 
    at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1045) 
    at org.apache.catalina.core.StandardHost.start(StandardHost.java:722) 
    at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1045) 
    at org.apache.catalina.core.StandardEngine.start(StandardEngine.java:443) 
    at org.apache.catalina.core.StandardService.start(StandardService.java:516) 
    at org.apache.catalina.core.StandardServer.start(StandardServer.java:710) 
    at org.apache.catalina.startup.Catalina.start(Catalina.java:593) 
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39) 
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25) 
    at java.lang.reflect.Method.invoke(Method.java:592) 
    at org.apache.catalina.startup.Bootstrap.start(Bootstrap.java:289) 
    at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:414) 
Caused by: com.rsa.ims.components.NoSuchComponentException: Unable to locate bean CommandAPIConnection 
    at com.rsa.ims.components.spring.SpringComponentManagerImpl.getBean(SpringComponentManagerImpl.java:71) 
    at com.rsa.command.ConnectionFactory.getSpringBeanTarget(ConnectionFactory.java:209) 
    ... 39 more 
Caused by: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'CacheableCommandTargetBasicAuth': FactoryBean threw exception on object creation; nested exception is java.lang.reflect.InvocationTargetException 
    at org.springframework.beans.factory.support.FactoryBeanRegistrySupport.doGetObjectFromFactoryBean(FactoryBeanRegistrySupport.java:150) 
    at org.springframework.beans.factory.support.FactoryBeanRegistrySupport.getObjectFromFactoryBean(FactoryBeanRegistrySupport.java:102) 
    at org.springframework.beans.factory.support.AbstractBeanFactory.getObjectForBeanInstance(AbstractBeanFactory.java:1387) 
    at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:301) 
    at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:189) 
    at org.springframework.context.support.AbstractApplicationContext.getBean(AbstractApplicationContext.java:1044) 
    at com.rsa.ims.components.spring.SpringComponentManagerImpl.getBean(SpringComponentManagerImpl.java:69) 
    ... 40 more 
Caused by: java.lang.reflect.InvocationTargetException 
    at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method) 
    at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:39) 
    at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:27) 
    at java.lang.reflect.Constructor.newInstance(Constructor.java:501) 
    at com.rsa.command.RemoteCommandTargetFactoryBean.getObject(RemoteCommandTargetFactoryBean.java:273) 
    at org.springframework.beans.factory.support.FactoryBeanRegistrySupport.doGetObjectFromFactoryBean(FactoryBeanRegistrySupport.java:143) 
    ... 46 more 
Caused by: java.lang.NoClassDefFoundError: weblogic/security/SSL/TrustManager 
    at java.lang.Class.forName0(Native Method) 
    at java.lang.Class.forName(Class.java:164) 
    at com.rsa.command.InitialContextFactoryLocator.getInitialContextFactory(InitialContextFactoryLocator.java:72) 
    at com.rsa.command.EJBRemoteTarget.<init>(EJBRemoteTarget.java:189) 
    ... 52 more 

Dans le projet com.wuntee.rsaAuthenticationManager, qui a la dépendance de la classe manquante est définie comme:

<dependency> 
    <groupId>com.rsa</groupId> 
    <artifactId>wlfullclient</artifactId> 
    <version>1.0</version> 
    <type>jar</type> 
    <scope>compile</scope> 
</dependency> 

Note: Cette dep peut également être ajouté au projet TAAC-web, et Je reçois toujours la même exception.

J'ai également confirmé que le .jar avec la classe est dans le répertoire WEB-INF/lib/répertoire du répertoire racine web tomcat, et que la classe existe ...:

./wlfullclient-1.0.jar 
weblogic/security/SSL/TrustManager.class 
weblogic/security/SSL/TrustManagerJSSE.class 

Répondre

3

Les dépendances Maven ne sont pas toujours transitives. Si TAAC-backend-IUG déclare sa dépendance à l'égard com.wuntee.rsaAuthenticationManager avec scope="test" ou optional="true", com.wuntee.rsaAuthenticationManager ne deviendra pas automatiquement une dépendance de com.wuntee.taac

Chacune de ces serait conforme à la symptômes que vous décrivez.

+0

Sauf que l'OP a également essayé d'ajouter l'artefact contenant 'WSS TrustManager' à la WAR avec le même résultat. –

+0

voir modifier sur l'original pour la définition dep – wuntee

0

En regardant à travers tous les journaux, je trouve ceci:

INFO: validateJarFile(/Users/wuntee/workspace/.metadata/.plugins/org.eclipse.wst.server.core/tmp1/wtpwebapps/taac-web/WEB-INF/lib/wlfullclient-1.0.jar) - jar not loaded. See Servlet Spec 2.3, section 9.7.2. Offending class: javax/servlet/Servlet.class 

qui vous expliquera pourquoi la classe ne peut pas être trouvé ...