Это генерирует соответствующий WSDL, который в свою очередь генерирует полезные заглушки Java.

аюсь разработать веб-сервис с JBossWS 3.1.2, который имеет HashMap в качестве одного из аргументов. Я использую эту версию JBossWS, потому что это то, что распространяется с версией JBoss, которую я использую. Я использую wsprovide для создания WSDL и wsconsume для создания заглушек клиента WS.

Упрощенная версия моего WebService:

@WebService(targetNamespace = "http://localhost/ping", serviceName = "Ping")
@SOAPBinding(style = SOAPBinding.Style.RPC)
public class Ping {
    @WebMethod
    @WebResult(name="result")
    public String ping(@WebParam(name="arguments") HashMap arguments) {
        return "pong";
    }
}

WSDL, созданный wsprovide, содержит:

<types>
    <xs:schema targetNamespace='http://localhost/ping' version='1.0' xmlns:tns='http://localhost/ping' xmlns:xs='http://www.w3.org/2001/XMLSchema'>
        <xs:complexType name='hashMap'>
            <xs:complexContent>
                <xs:extension base='tns:abstractMap'>
                    <xs:sequence/>
                </xs:extension>
            </xs:complexContent>
        </xs:complexType>
        <xs:complexType abstract='true' name='abstractMap'>
            <xs:sequence/>
        </xs:complexType>
    </xs:schema>
</types>

Сгенерированный код клиента содержит пустой абстрактный класс AbstractMap.java и пустой класс HashMap.

Я ожидал, что будет сгенерировано WSDL, похожее на следующее:

<complexType>
    <sequence>
        <element name="key" type="anyType" />
        <element name="value" type="anyType" />
    </sequence>
</complexType>

Я также попытался обернуть HashMap пользовательским классом (ParameterMap), но получил больше того же самого.

Есть ли следующий шаг, которого я не вижу? Я что-то упускаю или это ограничение восходящего подхода к разработке веб-сервисов с JBossWS?

Ответы на вопрос(1)

Ваш ответ на вопрос