I have XML string which I am trying to read with code
XmlDocument xmlDoc = new XmlDocument();
xmlDoc.LoadXml(XMLString);
XmlNode node = xmlDoc.SelectSingleNode("//cart/cart-item/url/text()");
Console.WriteLine(node.Value);
But node is always null. Could anyone explain what is wrong?
<order xmlns="http://ws.plimus.com">
<order-id>8301446</order-id>
<ordering-shopper>
<shopper-id>25879327</shopper-id>
</ordering-shopper>
<cart>
<charged-currency>USD</charged-currency>
<cart-item>
<sku>...</sku>
<quantity>1</quantity>
<url>
https://ws.plimus.com:443/services/2/subscriptions/9433117
</url>
<item-sub-total>9.00</item-sub-total>
</cart-item>
<tax>0.00</tax>
<tax-rate>0</tax-rate>
<total-cart-cost>9.00</total-cart-cost>
</cart>
</order>
By default XPath considers unprefixed names to be in “no namespace”. You should use
XmlNamespaceManagerto resolve xmlnsEdit:
If you have the possibility to change xml root element to
<order xmlns:ns="http://ws.plimus.com">then you don’t need to specify ‘ns’ in XPath every time, it would look like
//cart/cart-item/url/text().XmlNamespaceManagerconfiguration as shown in example is required anyway