Per Ansible FAQ :
Другое правило - «усы не стекают». Мы часто видим это:
{{ somevar_{{other_var}} }}
Вышеупомянутое НЕ РАБОТАЕТ, если вам нужно использовать динамическую переменную, используйте словарь хостов или vars соответственно:
blockquote>{{ hostvars[inventory_hostname]['somevar_' + other_var] }}
Итак, в вашем случае:
- debug: msg={{hostvars[inventory_hostname][Component].community_release_num}}
Или:
- debug: msg={{vars[Component].community_release_num}}
Или (поскольку Ansible 2.5):
- debug: msg={{(lookup('vars', Component)).community_release_num}}
Насколько я понимаю, ваша проблема сводится к тому, как вызвать веб-службу SOAP (JAX-WS) с Java и получить ее возвращаемый объект. В этом случае у вас есть два возможных подхода:
wsimport
и использовать их; или О первом подходе (используя wsimport
):
Я вижу, что у вас уже есть бизнес-классы служб (сущностей или других), и это факт, wsimport
генерирует целый новый набор классов (это как-то дубликаты классов, которые у вас уже есть).
Боюсь, что в этом случае вы можете только:
wsimport
, чтобы он использовал ваши бизнес-классы (это сложно и как-то не стоит - помните каждый раз, когда изменяется WSDL, вам придется регенерировать и читать код); или wsimport
. [В этом решении бизнес-код может «использовать» сгенерированные классы в качестве службы другого архитектурного уровня.) О втором подходе (создать свой пользовательский клиент SOAP):
Чтобы реализовать второй подход, вам необходимо:
java.net.HttpUrlconnection
(и некоторые java.io
обработки). Создание SOAP-клиента с использованием классического java.net.HttpUrlConnection
не так сложно (но не так просто), и вы можете найти в эту ссылку очень хороший старт код.
Я рекомендую использовать структуру SAAJ:
SOAP с API вложений для Java (SAAJ) в основном используется для непосредственного взаимодействия с сообщениями SOAP Request / Response, которые происходят за кулисами в любом API веб-сервисов. Это позволяет разработчикам напрямую отправлять и получать мыльные сообщения вместо JAX-WS.
blockquote>См. Ниже рабочий пример (запустите его!) Вызова веб-службы SOAP с помощью SAAJ. Он вызывает эту веб-службу .
import javax.xml.soap.*; public class SOAPClientSAAJ { // SAAJ - SOAP Client Testing public static void main(String args[]) { /* The example below requests from the Web Service at: https://www.w3schools.com/xml/tempconvert.asmx?op=CelsiusToFahrenheit To call other WS, change the parameters below, which are: - the SOAP Endpoint URL (that is, where the service is responding from) - the SOAP Action Also change the contents of the method createSoapEnvelope() in this class. It constructs the inner part of the SOAP envelope that is actually sent. */ String soapEndpointUrl = "https://www.w3schools.com/xml/tempconvert.asmx"; String soapAction = "https://www.w3schools.com/xml/CelsiusToFahrenheit"; callSoapWebService(soapEndpointUrl, soapAction); } private static void createSoapEnvelope(SOAPMessage soapMessage) throws SOAPException { SOAPPart soapPart = soapMessage.getSOAPPart(); String myNamespace = "myNamespace"; String myNamespaceURI = "https://www.w3schools.com/xml/"; // SOAP Envelope SOAPEnvelope envelope = soapPart.getEnvelope(); envelope.addNamespaceDeclaration(myNamespace, myNamespaceURI); /* Constructed SOAP Request Message: <SOAP-ENV:Envelope xmlns:SOAP-ENV="http://schemas.xmlsoap.org/soap/envelope/" xmlns:myNamespace="https://www.w3schools.com/xml/"> <SOAP-ENV:Header/> <SOAP-ENV:Body> <myNamespace:CelsiusToFahrenheit> <myNamespace:Celsius>100</myNamespace:Celsius> </myNamespace:CelsiusToFahrenheit> </SOAP-ENV:Body> </SOAP-ENV:Envelope> */ // SOAP Body SOAPBody soapBody = envelope.getBody(); SOAPElement soapBodyElem = soapBody.addChildElement("CelsiusToFahrenheit", myNamespace); SOAPElement soapBodyElem1 = soapBodyElem.addChildElement("Celsius", myNamespace); soapBodyElem1.addTextNode("100"); } private static void callSoapWebService(String soapEndpointUrl, String soapAction) { try { // Create SOAP Connection SOAPConnectionFactory soapConnectionFactory = SOAPConnectionFactory.newInstance(); SOAPConnection soapConnection = soapConnectionFactory.createConnection(); // Send SOAP Message to SOAP Server SOAPMessage soapResponse = soapConnection.call(createSOAPRequest(soapAction), soapEndpointUrl); // Print the SOAP Response System.out.println("Response SOAP Message:"); soapResponse.writeTo(System.out); System.out.println(); soapConnection.close(); } catch (Exception e) { System.err.println("\nError occurred while sending SOAP Request to Server!\nMake sure you have the correct endpoint URL and SOAPAction!\n"); e.printStackTrace(); } } private static SOAPMessage createSOAPRequest(String soapAction) throws Exception { MessageFactory messageFactory = MessageFactory.newInstance(); SOAPMessage soapMessage = messageFactory.createMessage(); createSoapEnvelope(soapMessage); MimeHeaders headers = soapMessage.getMimeHeaders(); headers.addHeader("SOAPAction", soapAction); soapMessage.saveChanges(); /* Print the request message, just for debugging purposes */ System.out.println("Request SOAP Message:"); soapMessage.writeTo(System.out); System.out.println("\n"); return soapMessage; } }
Об использовании JAXB для сериализации / десериализации очень легко найти информацию об этом. Вы можете начать здесь: http://www.mkyong.com/java/jaxb-hello-world-example/ .
Или просто используйте файл wsdl2java Apache CXF для создания объектов, которые вы можете использовать.
Он включен в бинарный пакет, который вы можете скачать со своего веб-сайта. Вы можете просто запустить команду следующим образом:
$ ./wsdl2java -p com.mynamespace.for.the.api.objects -autoNameResolution http://www.someurl.com/DefaultWebService?wsdl
Он использует wsdl для создания объектов, которые вы можете использовать таким образом (имена объектов также захватываются из wsdl, поэтому ваши будут немного отличаться ):
DefaultWebService defaultWebService = new DefaultWebService();
String res = defaultWebService.getDefaultWebServiceHttpSoap11Endpoint().login("webservice","dadsadasdasd");
System.out.println(res);
Существует даже подключаемый модуль Maven, который генерирует источники: https://cxf.apache.org/docs/maven-cxf-codegen-plugin-wsdl- to-java.html
Примечание. Если вы создаете источники с использованием CXF и IDEA, вы можете посмотреть на это: https://stackoverflow.com/a/46812593/ 840315