gpt4 book ai didi

java - SOAP WS - 使@WebParam 可选

转载 作者:搜寻专家 更新时间:2023-10-30 19:42:31 25 4
gpt4 key购买 nike

我有一个非常简单的方法,我通过 JAX-WS 注释在 WS API 中使用它:

@WebMethod
public MyResponse sendSingle2(
@WebParam(name="username") String username,
@WebParam(name="password") String password,
@WebParam(name="newParam") String newParam) {
// the code
}

现在我希望 newParam 是可选的。我的意思是我希望该方法不仅在传递的 xml 中的参数为空时仍然有效:

<ws:sendSingle2>
<username>user</username>
<password>pass</password>
<newParam></newParam>
</ws:sendSingle2>

而且当它不存在时:

<ws:sendSingle2>
<username>user</username>
<password>pass</password>
</ws:sendSingle2>

我需要它不破坏现有的 API,它可以在没有新参数的情况下工作。

最佳答案

@WebParam 将消息部分映射到参数,部分不能是可选的。参见 Optional Message Parts in WSDL .因此,简短的回答是,您所要求的正是无法完成的。但是,如果您可以重构此方法,则可以使用下述方法之一。

通常参数的可选性是通过模式 minOccurs=0 设置的。此外,您可以在架构中定义一个请求参数,而不是使用多个参数,您将其定义为 WebMethod 的参数。可选性现在封装在参数中,无论是否带有可选参数,都会调用相同的方法。

我更喜欢先定义契约,而不是依赖自动生成的文件。一旦您了解了 XSD、SOAP 和 WSDL 如何协同工作,您几乎不想再使用基于注释/代码优先的定义,因为反过来您会更加灵活。

代码示例:

<xs:schema
targetNamespace="http://your.namespace.com"
xmlns:tns="http://your.namespace.com"
xmlns:xs="http://www.w3.org/2001/XMLSchema"
elementFromDefault="qualified"
attributeFromDefault="qualified">

...

<xs:element name="MyRequest" type="tns:MyRequestType" />
<xs:element name="MyResponse" type="tns:MyResponseType" />

<xs:complexType name"MyRequestType">
<xs:sequence>
<xs:element name="username" type="xs:string" minOccurs="1" maxOccurs="1" />
<xs:element name="password" type="xs:string" minOccurs="1" maxOccurs="1" />
<xs:element name="newParam" type="xs:string" minOccurs="0" maxOccurs="1" />
</xs:sequence>
</xs:complexType>

...

</xs:schema>

在您的 WSDL 文件中,您可以像这样定义消息:

<wsdl:definitions
xmlns:soap="http://schemas.xmlsoap.org/wsdl/soap/"
xmlns:msg="http://your.namespace.com"
xmlns:xs="http://www.w3.org/2001/XMLSchema"
xmlns:http="http://schemas.xmlsoap.org/wsdl/http/"
xmlns:wsdl="http://schemas.xmlsoap.org/wsdl/"
xmlns:soapenc="http://schemas.xmlsoap.org/soap/encoding/"
targetNamespace="http://your.namespace.com">

<wsdl:types>
<xs:schema>
<!-- either import the externalized schema -->
<xs:import namespace="http://your.namespace.com"
schemaLocation="someDir/yourMessageSchema.xsd" />
</xs:schema>
<!-- or define the schema within the WSDL - just copy the schema here -->
<xs:schema
targetNamespace="http://your.namespace.com"
xmlns:tns="http://your.namespace.com"
xmlns:xs="http://www.w3.org/2001/XMLSchema"
elementFromDefault="qualified"
attributeFromDefault="qualified">
...
</xs:schema>
</wsdl:types>

...

<wsdl:message name="sendSingle2Request">
<wsdl:part name="in" element="msg:MyRequest" />
</wsdl:message>

<wsdl:message name="sendSingle2Response">
<wsdl:part name="out" element="msg:MyResponse" />
</wsdl:message>

...

<wsdl:portType name="YourServiceEndpoint">
<wsdl:operation name="sendSingle2">
<wsdl:input message="tns:sendSingle2Request" />
<wsdl:output message="tns:sendSingle2Response" />
</wsdl:operation>
...
</wsdl:portType>

<wsdl:binding name="YourServiceBinding" type="YourServiceEndpoint">
<soap:binding style="document" transport="http://schemas.xmlsoap.org/soap/http" />
<wsdl:operation name=""sendSingle2">
<soap:operation soapAction="http://your.namespace.com/SendSingle2" style="document" />
<wsdl:input>
<soap:body parts="in" use="literal" />
</wsdl:input>
<wsdl:output>
<soap:body parts="out" use="literal" />
</wsdl:output>
</wsdl:operation>
...
</wsdl:binding>

<wsdl:service name="YourService">
<wsdl:port name="YourServicePort binding="tns:YourServiceBinding">
<soap:address location="http://your.server:port/path/to/the/service" />
</wsdl:port>
</wsdl:service>
</wsdl:definitions>

此处的 WSDL 契约(Contract)定义使用样式:document/literal 并且在模式的帮助下,实际的 SOAP 消息将被document/literal wrapped,这也是 WS -我顺从。

因此你的方法将更改为 public MyResponse sendSinge2(MyRequest request) 其中 request 现在封装了 username, passowrdnewParam。如果 newParam 没有随 SOAP 请求一起发送,它只会返回 null,因此最好在使用它之前先检查一下。

如果您坚持代码优先的方法,您将需要首先定义您的 MyRequest 类,您将其用作请求参数而不是那些 2 或 3 个值。

@XmlAccessorType(XmlAccessType.FIELD)
@XmlRootElement(name = "MyRequest", namespace="http://your.namespace.com")
public class MyRequest implements Serializable
{
@XmlElement(name = "username", required = true)
protected String username;
@XmlElement(name = "password", required = true)
protected String password;
@XmlElement(name = "newParam", required = false)
protected String newParam;
...
}

如果您还没有为 MyResult 做同样的事情。 Web 方法现在可能看起来像这样:

@WebMethod(operationName = "sendSingle2")
@WebResult(name = "sendSingle2Response", targetNamespace = "http://your.namespace.com")
public MyResult sendSingle2(@WebParam(name = "sendSingle2Request") MyRequest request)
{
...
}

同样,request 封装了 3 个参数,您应该首先检查可选参数是否为 null。

HTH

关于java - SOAP WS - 使@WebParam 可选,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21179098/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com