AnsweredAssumed Answered

Error creando una nueva Action

Question asked by magarcia_sm on Apr 20, 2015
Latest reply on Apr 20, 2015 by magarcia_sm
Hola

Estoy intentando crear una acción siguiendo el capítulo 4 del Alfresco Developer Guide. El código es exactamente el mismo que en la guía. Creo el AMP y lo instalo sin problemas en el .war de Alfresco. El problema llega a la hora de ejecutar Tomcat, me salta el siguiente error.


14:17:24,458 INFO  [org.alfresco.config.xml.XMLConfigService$PropertyConfigurer] Loading properties file from class path resource [alfresco/file-servers.properties]
14:17:31,724 ERROR [org.springframework.web.context.ContextLoader] Context initialization failed
org.springframework.beans.factory.CannotLoadBeanClassException: Cannot find class [org.someco.web.action.executer.SetWebFlag] for bean with name 'SetWebFlag' defined in file [D:\Alfresco_temp2\tomcat\webapps\alfresco\WEB-INF\classes\alfresco\extension\someco-actions-context.xml]; nested exception is java.lang.ClassNotFoundException: org.someco.web.action.executer.SetWebFlag
Caused by: java.lang.ClassNotFoundException: org.someco.web.action.executer.SetWebFlag
   at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1387)
   at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1233)
   at org.springframework.util.ClassUtils.forName(ClassUtils.java:201)
   at org.springframework.beans.factory.support.AbstractBeanDefinition.resolveBeanClass(AbstractBeanDefinition.java:327)
   at org.springframework.beans.factory.support.AbstractBeanFactory.resolveBeanClass(AbstractBeanFactory.java:1075)
   at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:282)
   at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:352)
   at org.springframework.web.context.ContextLoader.createWebApplicationContext(ContextLoader.java:244)
   at org.springframework.web.context.ContextLoader.initWebApplicationContext(ContextLoader.java:187)
   at org.springframework.web.context.ContextLoaderListener.contextInitialized(ContextLoaderListener.java:49)
   at org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java:3843)
   at org.apache.catalina.core.StandardContext.start(StandardContext.java:4342)
   at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:791)
   at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:771)
   at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:525)
   at org.apache.catalina.startup.HostConfig.deployWAR(HostConfig.java:830)
   at org.apache.catalina.startup.HostConfig.deployWARs(HostConfig.java:719)
   at org.apache.catalina.startup.HostConfig.deployApps(HostConfig.java:490)
   at org.apache.catalina.startup.HostConfig.start(HostConfig.java:1149)
   at org.apache.catalina.startup.HostConfig.lifecycleEvent(HostConfig.java:311)
   at org.apache.catalina.util.LifecycleSupport.fireLifecycleEvent(LifecycleSupport.java:117)
   at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1053)
   at org.apache.catalina.core.StandardHost.start(StandardHost.java:719)
   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:578)
   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:597)
   at org.apache.catalina.startup.Bootstrap.start(Bootstrap.java:288)
   at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:413)
14:17:35,467 INFO  [org.alfresco.web.site.FrameworkHelper] Successfully Initialized Web Framework
14:17:37,626 INFO  [org.alfresco.web.scripts.DeclarativeRegistry] Registered 67 Web Scripts (+0 failed), 71 URLs
14:17:42,358 INFO  [org.alfresco.web.scripts.AbstractRuntimeContainer] Initialised Presentation Web Script Container (in 5033.1367ms)
14:18:43,314 INFO  [org.alfresco.web.scripts.DeclarativeRegistry] Registered 101 Web Scripts (+0 failed), 105 URLs
14:18:43,315 INFO  [org.alfresco.web.scripts.AbstractRuntimeContainer] Initialised WebFramework Web Script Container (in 60920.15ms)
14:18:43,376 INFO  [org.alfresco.web.site.FrameworkHelper] Successfully Initialized Web Framework


Entiendo que la causa es que no encuentra la clase "SetWebFlag"
El caso es que, una vez creado el amp e instalado en el alfresco.war, si busco esa clase en los .jar de "tomcat\webapps\alfresco\WEB-INF\lib" la clase si que existe en el archivo jar que se compila cuando ejecutamos el ant Build.xml, y la ruta es la correcta .

Este es nuestro someco-actions-context.xml


<?xml version='1.0' encoding='UTF-8'?>
<!DOCTYPE beans PUBLIC '-//SPRING//DTD BEAN//EN' 'http://www.springframework.org/dtd/spring-beans.dtd'>
<beans>
   <bean id="SetWebFlag" class="com.someco.web.action.executer.SetWebFlag" parent="action-executer">
      <property name="nodeService">
         <ref bean="NodeService" />
      </property>
      <property name="publicAction">
         <value>true</value>
      </property>
   </bean>
   <bean id="extension.actionResourceBundles" parent="actionResourceBundles">
      <property name="resourceBundles">
         <list>
            <value>alfresco.extension.somecoactions</value>
         </list>
      </property>
   </bean>
</beans>


y como podéis ver en el fichero adjunto el archivo Java existe en la ruta correcta.

En teoría el código esta bien porque esta tal cual como en el manual.
¿Alguna idea de porqué puede dar este error?

Muchas Gracias.

Attachments

Outcomes