5

尝试从示例 WSDL 构建演示合同优先服务(使用 CXF 2.7.1):

<?xml version='1.0' encoding='UTF-8'?>
<wsdl:definitions name="OrderProcessService" targetNamespace="http://order.demo/" xmlns:ns1="http://schemas.xmlsoap.org/soap/http" xmlns:soap="http://schemas.xmlsoap.org/wsdl/soap/" xmlns:tns="http://order.demo/" xmlns:wsdl="http://schemas.xmlsoap.org/wsdl/" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
    <wsdl:types>
        <xs:schema attributeFormDefault="unqualified" elementFormDefault="unqualified" targetNamespace="http://order.demo/" xmlns:tns="http://order.demo/" xmlns:xs="http://www.w3.org/2001/XMLSchema">
            <xs:element name="processOrder" type="tns:processOrder" />
            <xs:element name="processOrderResponse" type="tns:processOrderResponse" />
            <xs:complexType name="processOrder">
                <xs:sequence>
                    <xs:element minOccurs="0" name="arg0" type="tns:order" />
                </xs:sequence>
            </xs:complexType>
            <xs:complexType name="order">
                <xs:sequence>
                    <xs:element minOccurs="0" name="customerID" type="xs:string" />
                    <xs:element minOccurs="0" name="itemID" type="xs:string" />
                    <xs:element name="price" type="xs:double" />
                    <xs:element name="qty" type="xs:int" />
                </xs:sequence>
            </xs:complexType>
            <xs:complexType name="processOrderResponse">
                <xs:sequence>
                    <xs:element minOccurs="0" name="return" type="xs:string" />
                </xs:sequence>
            </xs:complexType>
        </xs:schema>
    </wsdl:types>
    <wsdl:message name="processOrderResponse">
        <wsdl:part element="tns:processOrderResponse" name="parameters">
        </wsdl:part>
    </wsdl:message>
    <wsdl:message name="processOrder">
        <wsdl:part element="tns:processOrder" name="parameters">
        </wsdl:part>
    </wsdl:message>
    <wsdl:portType name="OrderProcess">
        <wsdl:operation name="processOrder">
            <wsdl:input message="tns:processOrder" name="processOrder">
            </wsdl:input>
            <wsdl:output message="tns:processOrderResponse" name="processOrderResponse">
            </wsdl:output>
        </wsdl:operation>
    </wsdl:portType>
    <wsdl:binding name="OrderProcessServiceSoapBinding" type="tns:OrderProcess">
        <soap:binding style="document" transport="http://schemas.xmlsoap.org/soap/http" />
        <wsdl:operation name="processOrder">
            <soap:operation soapAction="" style="document" />
            <wsdl:input name="processOrder">
                <soap:body use="literal" />
            </wsdl:input>
            <wsdl:output name="processOrderResponse">
                <soap:body use="literal" />
            </wsdl:output>
        </wsdl:operation>
    </wsdl:binding>
    <wsdl:service name="OrderProcessService">
        <wsdl:port binding="tns:OrderProcessServiceSoapBinding" name="OrderProcessPort">
            <soap:address location="http://localhost:8080/OrderProcess" />
        </wsdl:port>
    </wsdl:service>
</wsdl:definitions>

我发布了以下内容:

wsdl2java -ant -impl -server -d src OrderProcess.wsdl

源代码生成很好,但是当我尝试使用 构建服务器时ant OrderProcessServer,我收到以下异常:

OrderProcessServer:
     [java] Starting Server
     [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:95)
     [java]     at org.apache.cxf.binding.soap.SoapBindingFactory.addListener(SoapBindingFactory.java:895)
     [java]     at org.apache.cxf.endpoint.ServerImpl.start(ServerImpl.java:131)
     [java]     at org.apache.cxf.jaxws.EndpointImpl.doPublish(EndpointImpl.java:360)
     [java]     at org.apache.cxf.jaxws.EndpointImpl.publish(EndpointImpl.java:251)
     [java]     at org.apache.cxf.jaxws.spi.ProviderImpl.createAndPublishEndpoint(ProviderImpl.java:152)
     [java]     at javax.xml.ws.Endpoint.publish(Endpoint.java:57)
     [java]     at demo.order.OrderProcess_OrderProcessPort_Server.<init>(OrderProcess_OrderProcessPort_Server.java:19)
     [java]     at demo.order.OrderProcess_OrderProcessPort_Server.main(OrderProcess_OrderProcessPort_Server.java:23)
     [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: 2 seconds

我的问题是:

  1. 什么钥匙?
  2. 如何提供它以便我不会得到异常?
  3. 为什么wsdl2java生成的代码不完整?(即.wsdl文件不够?)

更新: wsdl2java 命令生成的 ANTbuild.xml文件有这 2 行看似相关的行:

<sysproperty key="java.util.logging.config.file" value="${cxf.etc.dir}/logging.properties"/>
<sysproperty key="log4j.configuration" value="file:///${cxf.etc.dir}/log4j.properties"/>
  1. 他们是问题的关键(不是双关语)吗?
  2. 如果是这样,我应该放什么值来修复它?
  3. 如何告诉 wsdl2java 生成不需要修复的代码?
4

3 回答 3

5

Jetty 的 Log 实现正在读取系统属性,如下所示:

Enumeration<String> systemKeyEnum = Enumeration<String>)System.getProperties().propertyNames();

while (systemKeyEnum.hasMoreElements())
{
    String key = systemKeyEnum.nextElement();
    String val = System.getProperty(key);
    // ... (process key/values)
}

出于某种原因,您设法在系统属性中有一个空键:“”。因此,请检查您以编程方式设置系统属性 (System.setProperty) 的所有位置以及您的 java 命令行中的 -D 选项。如果这没有帮助,请尝试在此异常发生之前打印您的系统属性,或者执行 jpda 调试会话并在日志行 <122 或 System.checkKey() 处放置一个断点。

于 2013-01-10T10:33:31.857 回答
1

The empty keys come from the cxfrun macro in the generated ant script, build.xml.

Comment it out like so and you should be fine:

<arg value="@{param1}"/>
<arg value="@{param2}"/>
<arg value="@{param3}"/>
<arg value="@{param4}"/>
<arg value="@{param5}"/>
<jvmarg value="${cxf.endorsed.flag}"/>
<!-- Commented out to remove empty keys in system properties -->
<!-- jvmarg value="@{jvmarg1}"/>
<jvmarg value="@{jvmarg2}"/>
<jvmarg value="@{jvmarg3}"/>
<jvmarg value="@{jvmarg4}"/>
<jvmarg value="@{jvmarg5}"/ -->
于 2013-08-23T07:59:59.493 回答
0

空键也可以来自这种类型的“评论”:

=====================================

上面的这一行可能已被标记为注释,但系统会将等号视为键值标记。

于 2021-12-29T16:02:53.610 回答