Solved

Processing a soap response with javascript.. In IE

Posted on 2006-06-30
5
233 Views
Last Modified: 2012-05-05
Hello all im trying to consume a web service using javascript and soap but i cant seem to figure out how to getthe response,

Any help with this is greatly appreciated im at a loss on it

Here's what the soap response looks like
HTTP/1.1 200 OK
Content-Type: application/soap+xml; charset=utf-8
Content-Length: length

<?xml version="1.0" encoding="utf-8"?>
<soap12:Envelope xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:soap12="http://www.w3.org/2003/05/soap-envelope">
  <soap12:Body>
    <hintResponse xmlns="http://microsoft.com/webservices/">
      <hintResult>string</hintResult>
    </hintResponse>
  </soap12:Body>
</soap12:Envelope>


Here's the Code
             <script type="text/javascript" language=javascript>
 
  var xmlHttp;
  var  strEnvelope = "<?xml version='1.0' encoding='utf-8'?>"+
           " <soap12:Envelope xmlns:xsi='http://www.w3.org/2001/XMLSchema-instance'" +
      
          " xmlns:xsd='http://www.w3.org/2001/XMLSchema'" +
      
          " xmlns:soap12='http://www.w3.org/2003/05/soap-envelope'>" +
      
          "  <soap12:Body>" +
      
          "    <hint xmlns='http://microsoft.com/webservices'>" +
      
          "    <Term>b</Term></hint>" +
      
          "  </soap12:Body>" +
      
          "</soap12:Envelope>";

function showHint(str)
{
 
if (str.length > 0)
{
var url="http://localhost:3601/WebSite2/hint.asmx/hint";
xmlHttp=new ActiveXObject("Msxml2.XMLHTTP");
xmlHttp.open('POST', url , true);
xmlHttp.setRequestHeader("Content-Type","application/soap+xml; charset=utf-8")
xmlHttp.send(strEnvelope);
xmlHttp.onreadystatechange = checkState;
}
}
function checkState(){
  if(xmlHttp.readyState=="complete"||xmlHttp.readyState==4){
   placeHint(xmlHttp.responseXML);
     }
  else{
  alert("Not Complete");
  }
}
 function placeHint(xmlresponse) {
 alert(xmlresponse);
 response  = xmlresponse.documentElement;
  method = response.getElementsByTagName('hint')[0].firstChild.data;
  result = response.getElementsByTagName('Term')[0].firstChild.data;
}
</script>
 
I receive [object] in the alert inside of the placeHint function but then receive the error that response is null or not an object. Im not even sure if this is the best method for getting the data. Like i said id appreciate any insight
0
Comment
Question by:werD420
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 4
5 Comments
 

Author Comment

by:werD420
ID: 17020713
I changed to this but still have the same problems
 method = response.getElementsByTagName('hintResponse')[0].firstChild.data;
  result = response.getElementsByTagName('hintResult')[0].firstChild.data;
0
 

Author Comment

by:werD420
ID: 17021956
Here's the latest version im trying to load the response into another object then iterate through it but im getting nowhere i get two alerts that say object and one that says 4 . both appear to create and load but i cant figure out how to access the elements
     <script type="text/javascript" language=javascript>
 
  var xmlHttp;
  var  strEnvelope = "<?xml version='1.0' encoding='utf-8'?>"+
           " <soap:Envelope xmlns:xsi='http://www.w3.org/2001/XMLSchema-instance'" +
      
          " xmlns:xsd='http://www.w3.org/2001/XMLSchema'" +
      
          " xmlns:soap='http://www.w3.org/2003/05/soap-envelope'>" +
      
          "  <soap:Body>" +
      
          "    <hint xmlns='http://microsoft.com/webservices'>" +
      
          "    <Term>b</Term></hint>" +
      
          "  </soap:Body>" +
      
          "</soap:Envelope>";

function showHint(str)
{
 
if (str.length > 0)
{
var url="http://localhost:3601/WebSite2/hint.asmx/hint";
xmlHttp=new ActiveXObject("Msxml2.XMLHTTP");
xmlHttp.open('POST', url , true);
xmlHttp.setRequestHeader("Content-Type","text/xml; charset=utf-8")
xmlHttp.send(strEnvelope);
xmlHttp.onreadystatechange = checkState;
}
}
function checkState(){
  if(xmlHttp.readyState=="complete"||xmlHttp.readyState==4){
   placeHint(xmlHttp.responseXML);
   
     }
  else{
  alert("Not Complete");
  }
}
 function placeHint(xmlresponse) {
 var response;
 alert(xmlHttp.responseXML);
 oDoc =new ActiveXObject("MSXML2.DOMDocument.4.0")  
 oDoc.async = true;
 oDoc.setProperty("SelectionNamespaces","xmlns:soap='http://www.w3.org/2001/XMLSchema'")
 oDoc.load(xmlresponse)
 alert(oDoc.readyState);
 if(oDoc.readyState == 4 || oDoc.readyState == "complete"){
  result = oDoc.getElementsByTagName('hintResult')
 
  alert(result);
  }  else
  {
  alert("Not Ready")
}
}
</script>
0
 

Author Comment

by:werD420
ID: 17024384
Ive updated my placeHint function but i get object required are the alert line any thoughts?


 function placeHint(xmlresponse) {
 var resultNode;
 oDoc =new ActiveXObject("MSXML2.DOMDocument.4.0")  
 oDoc.async = false;
 oDoc.load(xmlresponse)
 var sNamespaces = "xmlns:soap='http://www.w3.org/2001/XMLSchema'" + " xmlns:default='http://microsoft.com/webservices/'";
 oDoc.setProperty("SelectionNamespaces",sNamespaces);
 var sXPath="/*/soap:Body/default:hintResponse/default:hintResult";
 resultNode = oDoc.selectSingleNode(sXPath);
 alert(resultNode.text);
}
0
 

Author Comment

by:werD420
ID: 17025846
well... I finished it on my own screw the soap i used a post and screw traversing xml with javascript this is an easy and good way to it using xslt

<script language=javascript type="text/javascript">
//posting data to webservice
function postdata(){
var url="http://localhost:3601/WebSite2/hint.asmx/hint";
xmlHttp=new ActiveXObject("Msxml2.XMLHTTP");
xmlHttp.open('POST', url , true);
xmlHttp.setRequestHeader("Content-Type","application/x-www-form-urlencoded");
var sendText=document.getElementById("Term").value
xmlHttp.send("Term="+sendText);
xmlHttp.onreadystatechange = checkState;
 }
 //checking for readiness
function checkState(){
  if(xmlHttp.readyState=="complete"||xmlHttp.readyState==4){
   placeHint2(xmlHttp.responseXML);
   }
}
//adding data to page through transform
function placeHint2(xmlresponse){
// Load XML
var xml = new ActiveXObject("Microsoft.XMLDOM")
xml.async = false
xml.load(xmlresponse)
// Load XSL
var xsl = new ActiveXObject("Microsoft.XMLDOM")
xsl.async = false
xsl.load("hint.xsl")
// Transform
document.getElementById("suggested").innerHTML =  xml.transformNode(xsl);
}
</script>
0
 

Accepted Solution

by:
EE_AutoDeleter earned 0 total points
ID: 17162178
werD420,
Because you have presented a solution to your own problem which may be helpful to future searches, this question is now PAQed and your points have been refunded.

EE_AutoDeleter
0

Featured Post

Get 15 Days FREE Full-Featured Trial

Benefit from a mission critical IT monitoring with Monitis Premium or get it FREE for your entry level monitoring needs.
-Over 200,000 users
-More than 300,000 websites monitored
-Used in 197 countries
-Recommended by 98% of users

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

This article will give core knowledge of JavaScript and will head in to your first JavaScript program. I am Durvesh Naik and I am here to deal with this series of JavaScript. I will teach you JavaScript in part wise , as its quite boring to read big…
JavaScript can be used in a browser to change parts of a webpage dynamically. It begins with the following pattern: If condition W is true, do thing X to target Y after event Z. Below are some tips and tricks to help you get started with JavaScript …
The viewer will learn the basics of jQuery, including how to invoke it on a web page. Reference your jQuery libraries: (CODE) Include your new external js/jQuery file: (CODE) Write your first lines of code to setup your site for jQuery.: (CODE)
The viewer will learn the basics of jQuery including how to code hide show and toggles. Reference your jQuery libraries: (CODE) Include your new external js/jQuery file: (CODE) Write your first lines of code to setup your site for jQuery…

695 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question