Go Premium for a chance to win a PS4. Enter to Win

  • Status: Solved
  • Priority: Medium
  • Security: Public
  • Views: 5005
  • Last Modified:

Need to remove Soap envelope to parse XML response

I am using asp.net 2.0 and a webservice that returns XML data as a string.
I am able successfully load the xml with XMLDocument.LoadXML(strXML). The response is inside a soap envelope in a plain text format.

How do I access the xml values ('LoginResponse' and SECTOKEN) as XML nodes without resorting to string manipulation (i.e. chopping off the soap enveleope, or using instr(SECTOKEN) to find the value).

That is, how do I remove the soap and get to the good stuff?

Example XML response below.

<?xml version="1.0" encoding="UTF-8"?><soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/"><soapenv:Body><ns:iws0005lResponse xmlns:ns="http://login.wsbeans.iseries/xsd"><ns:return><ns:_LS_OUTPUT_PARM_BUFF_STRUCT><ns:_LS_OUTPUT_PARM_BUFF>&lt;?xml version="1.0" encoding="UTF-8"?&gt;&#xD;
&lt;LoginResponse result="SUCCESS"&gt;&#xD;

Open in new window

1 Solution
You can locate the node containing the response using XPath passed to XmlDocument.SelectSingleNode(), and then refer to its InnerText property to get the formatted XML. Then, you can read this formatted XML and use XPath again to get to the actual result value. See my code below.
// Assumes you have your SOAP envelope already loaded into an XmlDocument named 'doc'
			XmlDocument doc = new XmlDocument();

			// Specify namespace manager to handle 'soapenv' and 'ns' namespaces
			NameTable nameTbl = new NameTable();
			XmlNamespaceManager nsMgr = new XmlNamespaceManager(nameTbl);
			nsMgr.AddNamespace("soapenv", "http://schemas.xmlsoap.org/soap/envelope/");
			nsMgr.AddNamespace("ns", "http://login.wsbeans.iseries/xsd");
			// Find the response element using XPath
			XmlNode outputElem = doc.SelectSingleNode("/soapenv:Envelope/soapenv:Body/ns:iws0005lResponse/ns:return/ns:_LS_OUTPUT_PARM_BUFF_STRUCT/ns:_LS_OUTPUT_PARM_BUFF", nsMgr);

			// Get response and remove leading white space (since xml declaration can't have leading whitespace)
			string responseText = outputElem.InnerText;
			responseText = responseText.Substring(responseText.IndexOf('<'));

			// responseText will now contain the actual response formatted as XML

			// Load response XML into XMLDocument

			// Find LoginResponse using XPath
			outputElem = doc.SelectSingleNode("/LoginResponse");

			// Get value of result attribute
			string result = outputElem.Attributes["result"].Value;

Open in new window

NELIXINCAuthor Commented:
Thank you so much. You're code works beautifully. Thanks especially for plugging in the namespace values from my example code. That was the part I was missing completely, and now I'm beginning to understand it.

Featured Post

Important Lessons on Recovering from Petya

In their most recent webinar, Skyport Systems explores ways to isolate and protect critical databases to keep the core of your company safe from harm.

Tackle projects and never again get stuck behind a technical roadblock.
Join Now