Как вызвать SOAP WS из Javascript/jQuery
Я бы назвал SOAP WebService непосредственно из Javascript. Я искал все вокруг, но все еще не могу что-то работать. Я предположил, что должен создать SOAP-конверт (см. Ниже). Я также использую jQuery.
Во-первых, я был бы уверен, что я могу назвать SOAP Webservice, расположенную где-то в другом месте? то есть нет ограничений, таких как ограничение перекрестного домена.
Также я не уверен, какой правильный URL мне нужно использовать, SOAP Service разоблачается с помощью Ladon, для цели отладки Я проверил, что WS хорошо работает с soapUI, и вот URL, которые я могу найти:
- URL WSDL:
http://192.168.1.5/ws/MyWS/soap/description
//из моего понимания это не может быть этот
- конечные точки службы:
http://192.168.1.5/ws/MyWS/soap
- SOAPAction:
http://192.168.1.5/ws/MyWS/soap/myOperation
Я думаю, что я должен использовать конечную точку или SOAPAction, но это не сработало. Я могу пропустить что-то здесь, или более поздний Javascript настолько ошибочен, что я не могу быть уверен.
Теперь вот мой фактический JS, выполняющий вызов (есть некоторые вопросы внутри комментариев):
<html>
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
<head>
<script type="text/javascript" src="ressources/jquery-1.7.1.min.js"></script>
<script type="text/javascript">
// inspired by http://openlandscape.net/2009/09/25/call-soap-xm-web-services-with-jquery-ajax/
var soapServiceURL = 'http://192.168.1.5/ws/MyWS/soap/myOperation; // not sure what to put here from a LADON point of view
function callSOAPWS(myParameter)
{
var soapMessage =
'<soapenv:Envelope xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:urn="urn:LDetector"> \
<soapenv:Header/> \
<soapenv:Body> \
<urn:myOperation soapenv:encodingStyle="http://schemas.xmlsoap.org/soap/encoding/"> \
<myParameter xsi:type="xsd:string">' + myParameter + '</myParameter > \
</urn:myOperation > \
</soapenv:Body> \
</soapenv:Envelope>';
alert("Check SOAP: [" + soapMessage + "]");
jQuery.ajax({
url: soapServiceURL,
type: "POST",
dataType: "xml",
data: soapMessage,
contentType: "text/xml; charset=\"utf-8\"",
//processData: false, // what is it for? may be should be true when using 'complete:' ?
//timeout: 5000,
// below I first try to have only 'complete:' then I tried to have 'success:' + 'error:', then the 3. Nothing seems to be ok. I do not find which one i should use.
complete: myCallback,
success: function( response ){
document.getElementById('debug').innerHTML = document.getElementById('debug').innerHTML + '\n' + 'success!' + '\n';
alert("success!!!");
},
error: function(XMLHttpRequest,textStatus, errorThrown){
document.getElementById('debug').innerHTML = document.getElementById('debug').innerHTML + '\n' + 'error : ' + textStatus + '\n';
alert("error : " + textStatus);
}
});
alert('if we reach this line, is it a fail?!');
return false;
}
function myCallback(xmlHttpRequest, status)
{
jQuery(xmlHttpRequest.responseXML)
.find('detected')
.each(function()
{
var result = jQuery(this).find('result').text();
document.getElementById('debug').innerHTML = document.getElementById('debug').innerHTML + '\n' + result + '\n';
alert('ok : [' + result + ']');
});
}
// https://stackoverflow.com/info/11916780/changing-getjson-to-jsonp?rq=1
jQuery(document).ready(function() {
callSOAPWS('this is a test');
});
</script>
<body>
<div id="debug" style="background-color:#EEEEEE; height:250px; width:600px; overflow:auto;"> </div>
</body>
</html>
С наилучшими пожеланиями
РЕДАКТИРОВАТЬ:, продолжая пытаться найти ответ, я прочитал, что = > Простейший пример SOAP, где Prestaul говорит: "Это не может выполняться с использованием прямого JavaScript, если веб-служба не находится в том же домене, что и ваша страница". так, может быть, я пытаюсь сделать что-то невозможное? это причина, почему он не может работать?
Ответы
Ответ 1
Вы не можете отправлять запросы AJAX с перекрестными доменами из-за ограничения той же политики происхождения, которое встроено в браузер. Для выполнения этой работы ваша HTML-страница, содержащая код jQuery, должна размещаться в том же домене, что и веб-служба (http://192.168.1.5/ws/MyWS/
).
Существуют обходные пути, которые включают использование JSONP на сервере, но поскольку ваш веб-сервис SOAP, это не сработает.
Единственный надежный способ сделать эту работу, если вы не можете переместить свой javascript в том же домене, что и веб-служба, для сборки серверной части script, которая будет размещаться в том же домене, что и код javascript, и будет действовать как мост между двумя доменами. Таким образом, вы отправите запрос AJAX на серверную сторону script, который, в свою очередь, вызовет удаленную веб-службу и вернет результат.
Ответ 2
Как насчет этого? https://github.com/doedje/jquery.soap
Кажется, достаточно легко. Возможно, это поможет вам.
Пример:
$.soap({
url: 'http://my.server.com/soapservices/',
method: 'helloWorld',
data: {
name: 'Remy Blom',
msg: 'Hi!'
},
success: function (soapResponse) {
// do stuff with soapResponse
// if you want to have the response as JSON use soapResponse.toJSON();
// or soapResponse.toString() to get XML string
// or soapResponse.toXML() to get XML DOM
},
error: function (SOAPResponse) {
// show error
}
});
приведет к
<soap:Envelope
xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/">
<soap:Body>
<helloWorld>
<name>Remy Blom</name>
<msg>Hi!</msg>
</helloWorld>
</soap:Body>
</soap:Envelope>
Ответ 3
ниже код работает нормально. может быть, это может вам помочь.
var SoaMessage = '<soapenv:Envelope xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" >'
+ '<soapenv:Header/>'
+ '<soapenv:Body>'
+ '<myoperation soapenv:encodingStyle="http://schemas.xmlsoap.org/soap/encoding/" xmlns="http://MyService/"> '
+ ' <AgencyId xsi:type="xsd:string">ADBC</AgencyId >'
+ '</myoperation >'
+ '</soapenv:Body>'
+ '</soapenv:Envelope>';
var url = "http://XXXXXXX/XXX/XXXXX?wsdl";
$.support.cors = true;
$.ajax({
type: "POST",
url: url,
jsonpCallback: "MyCallbackDED",
dataType: "xml",
processData: false,
contentType: "text/xml; charset=\"utf-8\"",
success: function (msg) {
alert("suc: " + msg.tradeLicenseData.master[0].arabicAddress + ": " + msg.tradeLicenseData.master[0].arabicAddress);
},
error: function (msg) {
alert("Failed: " + msg.status + ": " + msg.statusText);
}
});