我正在尝试使用 cxf 运行从 wsdl 生成的 web 服务。
- 获取示例 wsdl (hello_world.wsdl)
- 从 wsdl 生成 java 代码
- 'wsdl2java -ant -server -d 服务器 hello_world.wsdl'
- http://cxf.apache.org/docs/wsdl-to-java.html
- 由于生成的代码中缺少服务实现,我从这里得到了 GreeterImpl
- 'ant compile' 成功。
- 'ant GreeterServer' 不成功。
我错过了什么?
compile:
GreeterServer:
[java] Starting Server
[java] After implementor
[java] Before publish
[java] Exception in thread "main" java.lang.ExceptionInInitializerError
[java] at org.eclipse.jetty.util.component.AbstractLifeCycle.<clinit>(AbstractLifeCycle.java:33)
[java] at org.apache.cxf.transport.http_jetty.JettyHTTPDestination.activate(JettyHTTPDestination.java:178)
[java] at org.apache.cxf.transport.AbstractObservable.setMessageObserver(AbstractObservable.java:48)
[java] at org.apache.cxf.binding.AbstractBaseBindingFactory.addListener(AbstractBaseBindingFactory.java:97)
[java] at org.apache.cxf.binding.soap.SoapBindingFactory.addListener(SoapBindingFactory.java:901)
[java] at org.apache.cxf.endpoint.ServerImpl.start(ServerImpl.java:131)
[java] at org.apache.cxf.jaxws.EndpointImpl.doPublish(EndpointImpl.java:349)
[java] at org.apache.cxf.jaxws.EndpointImpl.publish(EndpointImpl.java:247)
[java] at org.apache.cxf.jaxws.spi.ProviderImpl.createAndPublishEndpoint(ProviderImpl.java:151)
[java] at javax.xml.ws.Endpoint.publish(Endpoint.java:57)
[java] at org.apache.hello_world_soap_http.Greeter_SoapPort_Server.<init>(Greeter_SoapPort_Server.java:21)
[java] at org.apache.hello_world_soap_http.Greeter_SoapPort_Server.main(Greeter_SoapPort_Server.java:26)
[java] Caused by: java.lang.IllegalArgumentException: key can't be empty
[java] at java.lang.System.checkKey(System.java:774)
[java] at java.lang.System.getProperty(System.java:647)
[java] at org.eclipse.jetty.util.log.Log$1.run(Log.java:122)
[java] at java.security.AccessController.doPrivileged(Native Method)
[java] at org.eclipse.jetty.util.log.Log.<clinit>(Log.java:85)
[java] ... 12 more
[java] Java Result: 1
BUILD SUCCESSFUL
Total time: 1 second