Hi JB,
Thanks for your help, I added cxfse service/endpoint and change
validateWsdl='no' but still cannot get it work. attached is source code.
SMX log:
DEBUG - AutoDeploymentService - SA dependencies: [servicemix-http,
servicemix-cxf-se]
DEBUG - DeploymentService - Moving
E:\progress\fuse-esb-3.4.0.2\data\smx\tmp\ejb-sa-1.0-SNAPSHOT.0.tmp to
E:\progress\fuse-esb-3.4.0.2\data\smx\service-assemblies\ejb-sa\version_1\install
DEBUG - DeploymentService - Unpack service unit archive
E:\progress\fuse-esb-3.4.0.2\data\smx\service-assemblies\ejb-sa\version_1\install\ejb-cxf-su-1.0-SNAPSHOT.zip
to
E:\progress\fuse-esb-3.4.0.2\data\smx\service-assemblies\ejb-sa\version_1\sus\servicemix-cxf-se\ejb-cxf-su
DEBUG - CxfSeComponent - Deploying service unit
DEBUG - CxfSeComponent - Looking for
E:\progress\fuse-esb-3.4.0.2\data\smx\service-assemblies\ejb-sa\version_1\sus\servicemix-cxf-se\ejb-cxf-su\xbean.xml:
true
-----------------------proxy:null
DEBUG - CxfSeComponent - Service unit deployed
DEBUG - DeploymentService - Unpack service unit archive
E:\progress\fuse-esb-3.4.0.2\data\smx\service-assemblies\ejb-sa\version_1\install\ejb-http-su-1.0-SNAPSHOT.zip
to
E:\progress\fuse-esb-3.4.0.2\data\smx\service-assemblies\ejb-sa\version_1\sus\servicemix-http\ejb-http-su
2009-6-11 13:18:38
org.apache.cxf.service.factory.ReflectionServiceFactoryBean
buildServiceFromClass
信息: Creating Service {http://demo/servicemix}LoginServiceService from class
demo.LoginService
2009-6-11 13:18:38 org.apache.cxf.configuration.spring.ConfigurerImpl
getBeanName
信息: Could not determine bean name for instance of class
org.apache.cxf.transport.jbi.JBIDestination.
2009-6-11 13:18:38 org.apache.cxf.endpoint.ServerImpl initDestination
信息: Setting the server's publish address to be
jbi://ID-192-168-83-151-121cd939b54-25-5
DEBUG - HttpComponent - Deploying service unit
DEBUG - HttpComponent - Looking for
E:\progress\fuse-esb-3.4.0.2\data\smx\service-assemblies\ejb-sa\version_1\sus\servicemix-http\ejb-http-su\xbean.xml:
true
DEBUG - HttpComponent - Service unit deployed
INFO - ServiceAssemblyLifeCycle - Starting service assembly: ejb-sa
INFO - ServiceUnitLifeCycle - Initializing service unit:
ejb-cxf-su
DEBUG - CxfSeComponent - Initializing service unit
DEBUG - ComponentContextImpl - Component: servicemix-cxf-se
activated endpoint: {http://demo/servicemix}LoginServiceService :
LoginServicePort
DEBUG - CxfSeComponent - Querying service description for
ServiceEndpoint[service={http://demo/servicemix}LoginServiceService,endpoint=LoginServicePort]
DEBUG - CxfSeComponent - No description found for
{http://demo/servicemix}LoginServiceService:LoginServicePort
DEBUG - WSDL1Processor - Endpoint
ServiceEndpoint[service={http://demo/servicemix}LoginServiceService,endpoint=LoginServicePort]
has no service description
DEBUG - CxfSeComponent - Querying service description for
ServiceEndpoint[service={http://demo/servicemix}LoginServiceService,endpoint=LoginServicePort]
DEBUG - CxfSeComponent - No description found for
{http://demo/servicemix}LoginServiceService:LoginServicePort
DEBUG - WSDL2Processor - Endpoint
ServiceEndpoint[service={http://demo/servicemix}LoginServiceService,endpoint=LoginServicePort]
has no service description
DEBUG - CxfSeComponent - Service unit initialized
INFO - ServiceUnitLifeCycle - Initializing service unit:
ejb-http-su
DEBUG - HttpComponent - Initializing service unit
DEBUG - JCAFlow - ServiceMix: broadcasting info for
org.apache.servicemix.jbi.event.EndpointEvent[source=ServiceEndpoint[service={http://demo/servicemix}LoginServiceService,endpoint=LoginServicePort]]
DEBUG - JMSFlow - ServiceMix: broadcasting info for
org.apache.servicemix.jbi.event.EndpointEvent[source=ServiceEndpoint[service={http://demo/servicemix}LoginServiceService,endpoint=LoginServicePort]]
DEBUG - HttpComponent - Service unit initialized
INFO - ServiceUnitLifeCycle - Starting service unit: ejb-cxf-su
DEBUG - CxfSeComponent - Starting service unit
DEBUG - CxfSeComponent - Unable to inject ComponentContext:
demo.LoginServiceImpl.setContext(javax.jbi.component.ComponentContext)
DEBUG - CxfSeComponent - Service unit started
INFO - ServiceUnitLifeCycle - Starting service unit: ejb-http-su
DEBUG - HttpComponent - Starting service unit
DEBUG - HttpComponent - Service unit started
INFO - AutoDeploymentService - Directory: hotdeploy: Finished
installation of archive: ejb-sa-1.0-SNAPSHOT.jar
1. http su still check the wsdl file
<jbi-task xmlns="http://java.sun.com/xml/ns/jbi/management-message"
version="1.0">
<jbi-task-result>
<frmwk-task-result>
<frmwk-task-result-details>
<task-result-details>
<task-id>start</task-id>
<task-result>FAILED</task-result>
<message-type>ERROR</message-type>
</task-result-details>
</frmwk-task-result-details>
</frmwk-task-result>
<component-task-result>
<component-name>servicemix-http</component-name>
<component-task-result-details>
<task-result-details>
<task-id>start</task-id>
<task-result>FAILED</task-result>
<message-type>ERROR</message-type>
<task-status-msg>
<msg-loc-info>
<loc-token/>
<loc-message>Unable to parse result string</loc-message>
</msg-loc-info>
</task-status-msg>
<exception-info>
<nesting-level>1</nesting-level>
<loc-token/>
<loc-message>Could not find service
'{http://demo/servicemix}LoginServiceService' in wsdl</loc-message>
<stack-trace><![CDATA[javax.jbi.management.DeploymentException: Could not
find service '{http://demo/servicemix}LoginServiceService' in wsdl
at
org.apache.servicemix.http.endpoints.HttpSoapConsumerEndpoint.validateWsdl1(HttpSoapConsumerEndpoint.java:374)
at
org.apache.servicemix.http.endpoints.HttpSoapConsumerEndpoint.activate(HttpSoapConsumerEndpoint.java:318)
at
org.apache.servicemix.common.DefaultServiceUnit.init(DefaultServiceUnit.java:54)
at
org.apache.servicemix.common.BaseServiceUnitManager.init(BaseServiceUnitManager.java:122)
at
org.apache.servicemix.jbi.framework.ServiceUnitLifeCycle.init(ServiceUnitLifeCycle.java:85)
at
org.apache.servicemix.jbi.framework.ServiceAssemblyLifeCycle.start(ServiceAssemblyLifeCycle.java:145)
at
org.apache.servicemix.jbi.framework.DeploymentService.start(DeploymentService.java:390)
at
org.apache.servicemix.jbi.framework.AutoDeploymentService.updateServiceAssembly(AutoDeploymentService.java:351)
at
org.apache.servicemix.jbi.framework.AutoDeploymentService.updateArchive(AutoDeploymentService.java:255)
at
org.apache.servicemix.jbi.framework.AutoDeploymentService.monitorDirectory(AutoDeploymentService.java:658)
at
org.apache.servicemix.jbi.framework.AutoDeploymentService.access$800(AutoDeploymentService.java:63)
at
org.apache.servicemix.jbi.framework.AutoDeploymentService$1.run(AutoDeploymentService.java:622)
at java.util.TimerThread.mainLoop(Timer.java:512)
at java.util.TimerThread.run(Timer.java:462)
]]></stack-trace>
</exception-info>
</task-result-details>
</component-task-result-details>
</component-task-result>
</jbi-task-result>
</jbi-task>
at
org.apache.servicemix.jbi.framework.ManagementSupport.failure(ManagementSupport.java:125)
at
org.apache.servicemix.jbi.framework.ManagementSupport.failure(ManagementSupport.java:111)
at
org.apache.servicemix.jbi.framework.ServiceAssemblyLifeCycle.start(ServiceAssemblyLifeCycle.java:168)
at
org.apache.servicemix.jbi.framework.DeploymentService.start(DeploymentService.java:390)
at
org.apache.servicemix.jbi.framework.AutoDeploymentService.updateServiceAssembly(AutoDeploymentService.java:351)
... 6 more
DEBUG - JMSFlow - ServiceMix: broadcasting info for
org.apache.servicemix.jbi.event.EndpointEvent[source=ServiceEndpoint[service={http://demo/servicemix}LoginServiceService,endpoint=LoginServicePort]]
2. If I create a wsdl file to match HTTP su service and endpoint, the su
can be deployed but get error message as below when access the service.
DEBUG - HttpComponent - Receiving HTTP request: GET
/LoginServiceService/ HTTP/1.1
Accept: image/gif, image/x-xbitmap, image/jpeg, image/pjpeg,
application/x-shockwave-flash, */*
Accept-Language: zh-cn
Accept-Encoding: gzip, deflate
User-Agent: Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1; MAXTHON
2.0)
Host: bjc-d-leonf-xp:8199
Connection: Keep-Alive
isUserJbiWrapper------------------true
DEBUG - PhaseInterceptorChain - Adding interceptor
org.apache.servicemix.soap.interceptors.mime.AttachmentsInInterceptor
DEBUG - PhaseInterceptorChain - Adding interceptor
org.apache.servicemix.soap.interceptors.xml.StaxInInterceptor
DEBUG - PhaseInterceptorChain - Adding interceptor
org.apache.servicemix.soap.bindings.soap.interceptors.SoapInInterceptor
DEBUG - PhaseInterceptorChain - Adding interceptor
org.apache.servicemix.soap.bindings.soap.interceptors.SoapActionInOperationInterceptor
DEBUG - PhaseInterceptorChain - Adding interceptor
org.apache.servicemix.soap.interceptors.wsdl.WsdlOperationInInterceptor
DEBUG - PhaseInterceptorChain - Adding interceptor
org.apache.servicemix.soap.bindings.soap.interceptors.MustUnderstandInterceptor
DEBUG - PhaseInterceptorChain - Adding interceptor
org.apache.servicemix.soap.interceptors.jbi.JbiInWsdl1Interceptor
DEBUG - PhaseInterceptorChain - Adding interceptor
org.apache.servicemix.soap.interceptors.jbi.JbiInInterceptor
DEBUG - PhaseInterceptorChain - Invoking handleMessage on
interceptor
org.apache.servicemix.soap.interceptors.mime.AttachmentsInInterceptor
INFO - PhaseInterceptorChain - Interceptor has thrown exception,
unwinding now
java.lang.NullPointerException: InputStream content not found
at
org.apache.servicemix.soap.interceptors.mime.AttachmentsInInterceptor.handleMessage(AttachmentsInInterceptor.java:46)
at
org.apache.servicemix.soap.core.PhaseInterceptorChain.doIntercept(PhaseInterceptorChain.java:85)
at
org.apache.servicemix.http.endpoints.HttpSoapConsumerMarshaler.createExchange(HttpSoapConsumerMarshaler.java:107)
at
demo.SoapConsumerMarshaler.createExchange(SoapConsumerMarshaler.java:29)
at
org.apache.servicemix.http.endpoints.HttpConsumerEndpoint.createExchange(HttpConsumerEndpoint.java:488)
at
org.apache.servicemix.http.endpoints.HttpConsumerEndpoint.process(HttpConsumerEndpoint.java:293)
at
org.apache.servicemix.http.HttpBridgeServlet.service(HttpBridgeServlet.java:56)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:690)
at
org.mortbay.jetty.servlet.ServletHolder.handle(ServletHolder.java:502)
at
org.mortbay.jetty.servlet.ServletHandler.handle(ServletHandler.java:363)
at
org.mortbay.jetty.handler.ContextHandler.handle(ContextHandler.java:766)
at
org.mortbay.jetty.handler.ContextHandlerCollection.handle(ContextHandlerCollection.java:230)
at
org.mortbay.jetty.handler.HandlerCollection.handle(HandlerCollection.java:114)
at
org.mortbay.jetty.handler.HandlerWrapper.handle(HandlerWrapper.java:152)
at org.mortbay.jetty.Server.handle(Server.java:324)
at
org.mortbay.jetty.HttpConnection.handleRequest(HttpConnection.java:534)
at
org.mortbay.jetty.HttpConnection$RequestHandler.headerComplete(HttpConnection.java:864)
at org.mortbay.jetty.HttpParser.parseNext(HttpParser.java:533)
at org.mortbay.jetty.HttpParser.parseAvailable(HttpParser.java:207)
at org.mortbay.jetty.HttpConnection.handle(HttpConnection.java:403)
at
org.mortbay.io.nio.SelectChannelEndPoint.run(SelectChannelEndPoint.java:409)
at
org.mortbay.thread.QueuedThreadPool$PoolThread.run(QueuedThreadPool.java:522)
DEBUG - PhaseInterceptorChain - Invoking handleFault on interceptor
org.apache.servicemix.soap.interceptors.mime.AttachmentsInInterceptor
DEBUG - PhaseInterceptorChain - Adding interceptor
org.apache.servicemix.soap.interceptors.xml.StaxOutInterceptor
DEBUG - PhaseInterceptorChain - Adding interceptor
org.apache.servicemix.soap.bindings.soap.interceptors.SoapOutInterceptor
DEBUG - PhaseInterceptorChain - Adding interceptor
org.apache.servicemix.soap.bindings.soap.interceptors.SoapFaultOutInterceptor
DEBUG - PhaseInterceptorChain - Invoking handleMessage on
interceptor org.apache.servicemix.soap.interceptors.xml.StaxOutInterceptor
DEBUG - PhaseInterceptorChain - Invoking handleMessage on
interceptor
org.apache.servicemix.soap.bindings.soap.interceptors.SoapOutInterceptor
DEBUG - PhaseInterceptorChain - Invoking handleMessage on
interceptor
org.apache.servicemix.soap.bindings.soap.interceptors.SoapFaultOutInterceptor
Jean-Baptiste Onofré wrote:
Hi,
Could you please provide the complete SMX log file ?
Could you try to define the service and endpoint in the cxfse:endpoint
definition ?
For your information, here is an EJB proxy using CXF-SE/HTTP that works
(using weblogic like you as backend).
First the CXF-SE SU xbean.xml:
<beans xmlns:cxfse="http://servicemix.apache.org/cxfse/1.0"
xmlns:fsb="http://www.fimasys.com/fsb">
<bean
class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
<property name="locations">
<value>classpath:/farm-report-service-config.properties</value>
</property>
</bean>
<cxfse:endpoint>
<cxfse:service>fsb:farm-report-service</cxfse:service>
<cxfse:endpoint>FarmReportServiceImplPort</cxfse:endpoint>
<cxfse:pojo>
<bean
class="com.fimasys.fsb.services.farmreport.FarmReportServiceImpl">
<property name="urlProvider"
value="${farm.jndiUrlProvider}"/>
<property name="jndiContextFactory"
value="${farm.jndiContextFactory}"/>
</bean>
</cxfse:pojo>
</cxfse:endpoint>
The FarmReportServiceImpl is the EJB client:
@WebService(serviceName = "farm-report-service", targetNamespace =
"http://www.fimasys.com/fsb", endpointInterface =
"com.fimasys.fsb.services.farmreport.FarmReportService")
public class FarmReportServiceImpl implements FarmReportService {
...
}
@WebService(targetNamespace = "http://www.fimasys.com/fsb", name =
"FarmReportService")
public interface FarmReportService {
/**
* @param reportCode the report code (mandatory)
* @param applicationCode the application code (mandatory)
* @param mediaType the media type (optional)
* @param asynchronousTimeout the asynchronous timeout (optional)
* @param reportParameters the parameters specific to this report
(optional)
* @return the result as a byte array, may be null as some report do
not return an output stream
* @throws ReportingException
*/
public byte[] executeReport( @WebParam(name="reportCode") String
reportCode,
@WebParam(name="applicationCode") String
applicationCode,
@WebParam(name="mediaType") String
mediaType,
@WebParam(name="asynchronousTimeout")
Integer asynchronousTimeout,
@WebParam(name="reportParameters")
List<ReportParameter> reportParameters) throws ReportingException;
}
On the HTTP SU, I have the xbean.xml:
<http:soap-consumer service="fsb:farm-report-service"
endpoint="fsb:farm-report-service-http"
targetService="fsb:farm-report-service"
targetEndpoint="FarmReportServiceImplPort"
locationURI="${service.locationURI}"
wsdl="classpath:farm-report.wsdl"
validateWsdl="no"/>
Regards
JB
laolong wrote:
Hi
I'm a newcomer of servicemix, I'm going to make a EJB proxy to expose
my
EJB as webservice, but always get 'Cound not find port LoginServicePort
in
wsdl for service {http://demo/servicemix}LoginService' error since
loginservice.wsdl is a 'fake' WSDL , looks like validateWsdl="false" is
not
working, how can I disable it?
My code is created according to ServiceMix Tutorials ---Using EJB
inside
ServiceMix(http://cwiki.apache.org/SM/6-intermediate-using-ejb-inside-servicemix.html)
It will be great help to provide a working example of EJB proxy, thanks
in
advance!
ejb-http-su xbean.xml
<beans xmlns:http="http://servicemix.apache.org/http/1.0"
xmlns:tns="http://demo/servicemix">
<http:soap-consumer
service="tns:LoginService"
endpoint="ep"
targetService="tns:LoginService"
targetEndpoint="LoginServicePort"
defaultMep="http://www.w3.org/2004/08/wsdl/in-out"
locationURI="http://0.0.0.0:8199/LoginServiceService"
wsdl="classpath:loginservice.wsdl"
validateWsdl="false"
useJbiWrapper="true"
/>
</beans>
cxfse xbean.xml
<beans xmlns:cxfse="http://servicemix.apache.org/cxfse/1.0"
xmlns:tns="http://demo/servicemix">
<bean id="jndiTemplate" class="org.springframework.jndi.JndiTemplate">
<property name="environment">
<props>
<prop key="java.naming.factory.initial">
weblogic.jndi.WLInitialContextFactory
</prop>
<prop key="java.naming.provider.url">
t3://192.168.80.111:7001
</prop>
</props>
</property>
</bean>
<bean id="ejbProxy"
class="org.springframework.ejb.access.SimpleRemoteStatelessSessionProxyFactoryBean">
<property name="jndiName" value="demo/UserDAORemote"/>
<property name="businessInterface" value="demo.UserDAORemote"/>
<property name="homeInterface" value="demo.UserDAORemoteHome"/>
<property name="refreshHomeOnConnectFailure" value="true"/>
<property name="cacheHome" value="true"/>
<property name="lookupHomeOnStartup" value="false"/>
<property name="resourceRef" value="true"/>
<property name="jndiTemplate" ref="jndiTemplate"/>
</bean>
<cxfse:endpoint>
<cxfse:pojo>
<bean class="demo.LoginServiceImpl">
<property name="proxy" ref="ejbProxy"/>
</bean>
</cxfse:pojo>
</cxfse:endpoint>
</beans>
http://www.nabble.com/file/p23975536/sm-ejb-proxy.zip sm-ejb-proxy.zip