2010-03-21 4 views
1

Je veux créer un appel de service Web dynamique dans JSF avec CXF. Mais quand je charge ce code simple, j'ai une erreur. Le code:Pourquoi je reçois cette erreur dans CXF

JaxWsDynamicClientFactory dcf = JaxWsDynamicClientFactory.newInstance(); 
Client client = dcf.createClient("http://ws.strikeiron.com/IPLookup2?wsdl"); 

L'erreur:

Aucune usine configuré pour cette application. Cela se produit si l'initialisation des visages ne fonctionne pas du tout - assurez-vous que vous incluez correctement tous les paramètres de configuration nécessaires pour une application de visages de base et que toutes les bibliothèques nécessaires sont incluses. Vérifiez également la sortie de journalisation de votre application Web et votre conteneur pour toutes les exceptions! Si vous l'avez fait et que vous ne trouvez rien, l'erreur peut être due au fait que vous utilisez des conteneurs web spéciaux qui ne supportent pas l'enregistrement de contextes-écouteurs via les fichiers TLD et un écouteur de contexte n'est pas configuré dans votre fichier web.xml. Une config typique ressemble à ceci; org.apache.myfaces.webapp.StartupServletContextListener

Causée par: java.lang.IllegalStateException - Aucune installation configurée pour cette application. Cela se produit si l'initialisation des visages ne fonctionne pas du tout - assurez-vous que vous incluez correctement tous les paramètres de configuration nécessaires pour une application de visages de base et que toutes les bibliothèques nécessaires sont incluses. Vérifiez également la sortie de journalisation de votre application Web et votre conteneur pour toutes les exceptions! Si vous l'avez fait et que vous ne trouvez rien, l'erreur peut être due au fait que vous utilisez des conteneurs web spéciaux qui ne supportent pas l'enregistrement de contextes-écouteurs via les fichiers TLD et un écouteur de contexte n'est pas configuré dans votre fichier web.xml. Une config typique ressemble à ceci; org.apache.myfaces.webapp.StartupServletContextListener

Une idée Comment résoudre le problème?

web.xml

<?xml version="1.0" encoding="UTF-8"?> 
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" id="WebApp_ID" version="2.5"> 
    <display-name>ServiceInvoker</display-name> 
    <welcome-file-list> 
    <welcome-file>index.html</welcome-file> 
    <welcome-file>index.htm</welcome-file> 
    <welcome-file>index.jsp</welcome-file> 
    <welcome-file>default.html</welcome-file> 
    <welcome-file>default.htm</welcome-file> 
    <welcome-file>default.jsp</welcome-file> 
    </welcome-file-list> 
    <servlet> 
    <servlet-name>Faces Servlet</servlet-name> 
    <servlet-class>javax.faces.webapp.FacesServlet</servlet-class> 
    <load-on-startup>1</load-on-startup> 
    </servlet> 
    <servlet-mapping> 
    <servlet-name>Faces Servlet</servlet-name> 
    <url-pattern>*.jsf</url-pattern> 
    </servlet-mapping> 
    <context-param> 
    <param-name>javax.servlet.jsp.jstl.fmt.localizationContext</param-name> 
    <param-value>resources.application</param-value> 
    </context-param> 
    <context-param> 
    <description>State saving method: 'client' or 'server' (=default). See JSF Specification 2.5.2</description> 
    <param-name>javax.faces.STATE_SAVING_METHOD</param-name> 
    <param-value>client</param-value> 
    </context-param> 
    <context-param> 
    <description> 
    This parameter tells MyFaces if javascript code should be allowed in 
    the rendered HTML output. 
    If javascript is allowed, command_link anchors will have javascript code 
    that submits the corresponding form. 
    If javascript is not allowed, the state saving info and nested parameters 
    will be added as url parameters. 
    Default is 'true'</description> 
    <param-name>org.apache.myfaces.ALLOW_JAVASCRIPT</param-name> 
    <param-value>true</param-value> 
    </context-param> 
    <context-param> 
    <description> 
    If true, rendered HTML code will be formatted, so that it is 'human-readable' 
    i.e. additional line separators and whitespace will be written, that do not 
    influence the HTML code. 
    Default is 'true'</description> 
    <param-name>org.apache.myfaces.PRETTY_HTML</param-name> 
    <param-value>true</param-value> 
    </context-param> 
    <context-param> 
    <param-name>org.apache.myfaces.DETECT_JAVASCRIPT</param-name> 
    <param-value>false</param-value> 
    </context-param> 
    <context-param> 
    <description> 
    If true, a javascript function will be rendered that is able to restore the 
    former vertical scroll on every request. Convenient feature if you have pages 
    with long lists and you do not want the browser page to always jump to the top 
    if you trigger a link or button action that stays on the same page. 
    Default is 'false' 
</description> 
    <param-name>org.apache.myfaces.AUTO_SCROLL</param-name> 
    <param-value>true</param-value> 
    </context-param> 
    <listener> 
    <listener-class>org.apache.myfaces.webapp.StartupServletContextListener</listener-class> 
    </listener> 
</web-app> 

faces-config.xml

<?xml version="1.0" encoding="UTF-8"?> 

<faces-config 
    xmlns="http://java.sun.com/xml/ns/javaee" 
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
    xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-facesconfig_1_2.xsd" 
    version="1.2"> 
    <managed-bean> 
     <description>Bean used for invoking services</description> 
     <managed-bean-name>invoker</managed-bean-name> 
     <managed-bean-class>org.cot.invoker.Invoker</managed-bean-class> 
     <managed-bean-scope>session</managed-bean-scope> 
    </managed-bean> 

</faces-config> 

C'est ce que je reçois dans la console dans Eclipse:

22.3.2010 15: 00:11 org.apache.cxf.endpoint.dynamic.DynamicClientFactory outputDebug INFO: classes créées: com.strikeiron.ws.GetRemainingHits, com.strikeiron.ws.GetRemainingHitsResponse, com.strikeiron.ws.LicenseInfo, com.strikeiron.ws.ObjectFactory, com.strikeiron.ws.RegisteredUser, com.strikeiron.ws.SubscriptionInfo, com. strikeiron.ws.UnregisteredUser, com.strikeiron.ArrayOfMethodStatusRecord, com.strikeiron.ArrayOfSIWsStatus, com.strikeiron.ArrayOfServiceInfoEnregistrement, com.strikeiron.ArrayOfString, com.strikeiron.ArrayOfString1, com.strikeiron.DNSInfo, com.strikeiron.DNSLookup, com. strikeiron.DNSLookupResponse, com.strikeiron.GetServiceInfo, com.strikeiron.GetServiceInfoResponse, com.strikeiron.GetStatusCodes, com.strikeiron.GetStatusCodesForMéthode, com.strikeiron.GetStatusCodesForMethodResponse, com.strikeiron.GetStatusCodesResponse, com.strikeiron.MethodStatusRecord, com.strikeiron. ObjectFactory, com.strikeiron.SIWsOutputOfDNSInfo, com.strikeiron.SIWsOutputOfMethodStatusRecord, com.strikeiron.SIWsOutputOfSIWsResultArrayOfMethodStatusRecord, com.strikeiron.SIWsOutputOfSIWsResultArrayOfSer viceInfoRecord, com.strikeiron.SIWsResultArrayOfMethodStatusRecord, com.strikeiron.SIWsResultArrayOfSIWsStatus, com.strikeiron.SIWsResultArrayOfServiceInfoRecord, com.strikeiron.SIWsStatus, com.strikeiron.ServiceInfoRecord je slo 22.03.2010 15:00:13 javax.faces.webapp._ErrorPageWriter handleThrowable SEVERE: Une exception est survenue java.lang.IllegalStateException: Aucune installation configurée pour cette application.Cela se produit si l'initialisation des visages ne fonctionne pas du tout - assurez-vous que vous incluez correctement tous les paramètres de configuration nécessaires pour une application de visages de base et que toutes les bibliothèques nécessaires sont incluses. Vérifiez également la sortie de journalisation de votre application Web et votre conteneur pour toutes les exceptions! Si vous faites cela et ne trouvez rien, l'erreur peut être due au fait que vous utilisez des conteneurs web spéciaux qui ne supportent pas l'enregistrement de contextes-écouteurs via les fichiers TLD et un écouteur de contexte n'est pas configuré dans votre fichier web.xml. Une config typique ressemble à ceci; org.apache.myfaces.webapp.StartupServletContextListener

at javax.faces.FactoryFinder.getFactory(FactoryFinder.java:106) 
at org.apache.myfaces.application.jsp.JspViewHandlerImpl.renderView(JspViewHandlerImpl.java:356) 
at org.apache.myfaces.lifecycle.RenderResponseExecutor.execute(RenderResponseExecutor.java:41) 
at org.apache.myfaces.lifecycle.LifecycleImpl.render(LifecycleImpl.java:140) 
at javax.faces.webapp.FacesServlet.service(FacesServlet.java:155) 
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290) 
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206) 
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:233) 
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:191) 
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:127) 
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102) 
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109) 
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:298) 
at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:852) 
at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:588) 
at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:489) 
at java.lang.Thread.run(Unknown Source) 

lorsque je clique sur:

<h:commandLink value="Invoke me!" actionListener="#{invoker.doInvoke}"></h:commandLink> 
+0

nous montrent les 'faces-config.xml 'et' web.xml' – Bozho

+0

J'ajoute aussi faces-config.xml et web.xml. Hm ... Im déjà 2 jours en essayant de résoudre ce problème – Milan

+0

Y at-il d'autres exceptions/erreurs dans les fichiers journaux? Comme 'NoClassDefFound', par exemple – Bozho

Répondre

0

Les erreurs que vous citez n'a rien à voir avec CXF, mais plutôt avec org.apache.myfaces .

Si tout ce qui revient du serveur, alors vous avez la mauvaise URL pour le? Wsdl. La navigation sur cette URL produit-elle le fichier WSDL dans un navigateur ordinaire?

Vous pouvez probablement obtenir une meilleure assistance de débogage à ce sujet sur la liste de diffusion des utilisateurs CXF. Ce n'est pas vraiment une question comme un problème de diagnostic qui va prendre beaucoup de va-et-vient.

+0

Le wsdl? l'url est ok. Dans un navigateur ordinaire, je vois le document WSDL. Probablement le problème est dans le myFaces. Mais où .... Je n'ai pas idée. – Milan

1

Afin d'éviter une erreur comme « Aucune usine configuré pour cette application » à l'aide d'un CXF client dynamique et JSF, vous devez faire quelque chose comme ceci:

ClassLoader classLoader = Thread.currentThread().getContextClassLoader(); 
JaxWsDynamicClientFactory dcf = JaxWsDynamicClientFactory.newInstance(); 
Client client = dcf.createClient("http://ws.strikeiron.com/IPLookup2?wsdl"); 
Thread.currentThread().setContextClassLoader(classLoader); 
Questions connexes