Я собираюсь разработать расширение для Firefox, которое сделает запрос XMLHttpRequest для этого WebService.
Я могу правильно запросить службу с помощью следующего кода (из файла overlay.js):
var req = "<soapenv:Envelope xmlns:soapenv=\"http://schemas.xmlsoap.org/soap/envelope/\" xmlns:dat=\"http://webservice.whereisnow.com/datatypes\"><soapenv:Header/><soapenv:Body><dat:CurrentDocument><dat:applicationId>1</dat:applicationId><dat:publisherId>84</dat:publisherId><dat:documentId>8</dat:documentId><dat:versionId>1</dat:versionId></dat:CurrentDocument></soapenv:Body></soapenv:Envelope>"; var xmlhttpreq = Components.classes["@mozilla.org/xmlextras/xmlhttprequest;1"].createInstance(Components.interfaces.nsIXMLHttpRequest); xmlhttpreq.open("POST","https://www.whereisnow.com/webservice",false); // false = async xmlhttpreq.channel.loadFlags |= Components.interfaces.nsIRequest.LOAD_BYPASS_CACHE; xmlhttpreq.send(req); if (xmlhttpreq.readyState == 4){ if(xmlhttpreq.status == 200) alert(xmlhttpreq.responseText); else alert("Error: xmlhttpreq.status = " + xmlhttpreq.status) } else alert("Not ready: xmlHttpreq.readyState = " + xmlHttpreq.readyState);
responseText будет действительным xml, которым я могу манипулировать, но к WebService можно получить доступ как через http, так и через https (SSL), и я ДОЛЖЕН сделать это через https, потому что для выполнения некоторых операций требуется аутентификация прочее.
Чтобы получить доступ через https, я ДОЛЖЕН изменить конечную точку, используя https: // вместо http: // и запросить xml следующим образом:
var req = "<soapenv:Envelope xmlns:dat=\"http://webservice.whereisnow.com/datatypes\" xmlns:soapenv=\"http://schemas.xmlsoap.org/soap/envelope/\"><soapenv:Header><wsse:Security xmlns:wsse=\"http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-secext-1.0.xsd\"><wsse:UsernameToken wsu:Id=\"UsernameToken-1\" xmlns:wsu=\"http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-utility-1.0.xsd\"><wsse:Username>MY_USERNAME</wsse:Username><wsse:Password Type=\"http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-username-token-profile-1.0#PasswordText\">SHA1_OF_MY_PASSWORD</wsse:Password></wsse:UsernameToken></wsse:Security></soapenv:Header><soapenv:Body><dat:CurrentDocument><dat:applicationId>1</dat:applicationId><dat:publisherId>84</dat:publisherId><dat:documentId>10</dat:documentId><dat:versionId>1</dat:versionId></dat:CurrentDocument></soapenv:Body></soapenv:Envelope>";
Проблема в том, что статус сервера всегда 500, а responseText всегда такой:
<?xml version='1.0' encoding='UTF-8'?><soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/"><soapenv:Body><soapenv:Fault><faultcode>soapenv:Server</faultcode><faultstring>InvalidSecurity</faultstring><detail></detail></soapenv:Fault></soapenv:Body></soapenv:Envelope>
Любая помощь?
EDIT
С кодом, найденным на этом URL Я обнаружил, что SSL-сертификат службы работает правильно. Так что я думаю, что проблема не в https ...
решено добавить следующие строки после открытия (...):
xmlhttpreq.setRequestHeader("Content-Type", "text/xml; charset=utf-8"); xmlhttpreq.setRequestHeader("SOAPAction", "whereIsNow");