C# Examples

ChilkatHOMEAndroid™ASPVisual BasicVB.NETC#iOS (IPhone)Objective-CC++CMFCDelphiFoxProJavaPerl
PHP ExtensionPHP ActiveXPythonPowerShellRubySQL ServerVBScript

C# Examples

Bounced Mail
Bz2
Character Encoding
CSV
DKIM / DomainKey
Digital Certificates
Digital Signatures
Email
Email Object
FTP
HTML Conversion
HTTP
IMAP
Encryption
MHT / HTML Email
MIME
POP3
RSA
S/MIME
SMTP
Socket
Spider
SSH
SSH Tunnel
SSH Key
SFTP
Tar Archive
Upload
XML
XMP
Zip Compression


More Examples...
Amazon S3
NTLM
FileAccess
RSS
Atom
String
Byte Array
Self-Extractor
Service
PPMD
Deflate
DH Key Exchange
DSA
Bzip2
LZW

 

 

 

 

 

 

Parse SOAP XML Response

Code to parse a SOAP XML response.

This is the SOAP response parsed by the code below:

<?xml version="1.0"?>
<soap:Envelope
xmlns:soap="http://www.w3.org/2001/12/soap-envelope"
soap:encodingStyle="http://www.w3.org/2001/12/soap-encoding">

<soap:Body xmlns:m="http://www.example.org/stock">
  <m:GetStockPriceResponse>
    <m:Price>34.5</m:Price>
  </m:GetStockPriceResponse>
</soap:Body>

Download: Chilkat .NET Assemblies

bool success;
bool bFound;
Chilkat.Xml xml = new Chilkat.Xml();

//  Load the XML object with the SOAP response.
//  The XML may be loaded from a file by calling
//  LoadXmlFile, or directly from a string by calling
//  LoadXml.
success = xml.LoadXmlFile("soapResponse.xml");
if (success != true) {
    textBox1.Text += xml.LastErrorText + "\r\n";
    return;
}

//  The quickest way to get a piece of data is w/ the
//  ChilkatPath method.
//  To get the content of the m:Price node:
string strPrice;
strPrice = xml.ChilkatPath("soap:Body|m:GetStockPriceResponse|m:Price|*");
textBox1.Text += "Price = " + strPrice + "\r\n";

//  ------------------------------------
//  Another way of doing it:

//  Another way to get it is to navigate to the node.
//  Navigate to soap:Body
xml.FirstChild2();

//  Navigate to m:GetStockPriceResponse
//  You may call FirstChild2, or you may call GetChildWithTag2
//  to get the Nth direct child having a given tag.
//  In this case, get the 1st direct child having the tag
//  "m:GetStockPriceResponse"
//  (Indexing begins at 0, so the 1st occurance is at index 0.)
bFound = xml.GetNthChildWithTag2("m:GetStockPriceResponse",0);
if (bFound != true) {
    textBox1.Text += "Did not find m:GetStockPriceResponse node." + "\r\n";
    return;
}

//  One more to go..
bFound = xml.GetNthChildWithTag2("m:Price",0);
if (bFound != true) {
    textBox1.Text += "Did not find m:Price node." + "\r\n";
    return;
}

//  The content of the "m:Price" node is "34.5"
strPrice = xml.Content;
textBox1.Text += "Price = " + strPrice + "\r\n";

//  Restore the xml object's internal reference to the root
//  of the XML document:
xml.GetRoot2();

//  ------------------------------------
//  Another way of doing it:

//  If you know that the node w/ the content you want to
//  extract is uniquely tagged (i.e. no other node has the same
//  tag), then search for the node having the tag:
bFound = xml.SearchForTag2(xml,"m:Price");
if (bFound != true) {
    //  Not found...
    return;
}

//  The content of the "m:Price" node is "34.5"
strPrice = xml.Content;
textBox1.Text += "Price = " + strPrice + "\r\n";

//  Restore the xml object's internal reference to the root
//  of the XML document:
xml.GetRoot2();

//  ------------------------------------
//  Another way of doing it:

//  Again, assuming there is only a single node with the
//  tag to be fetched:
strPrice = xml.AccumulateTagContent("m:Price","");
textBox1.Text += "Price = " + strPrice + "\r\n";

//  There are many other possible ways of doing the same thing...

 

© 2000-2012 Chilkat Software, Inc. All Rights Reserved.

Email Component · XML Parser