分析来自服务 asp.net 的 XML 响应



我正在尝试将Web服务与我的项目集成。Web 服务返回一个 XML 响应:

<?xml version="1.0" encoding="UTF-8"?>
<SOAP-ENV:Envelope xmlns:SOAP-ENV="http://schemas.xmlsoap.org/soap/envelope/" 
xmlns:ns1="http://www.tpg.ua/" 
xmlns:xsd="http://www.w3.org/2001/XMLSchema" 
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
xmlns:SOAP-ENC="http://schemas.xmlsoap.org/soap/encoding/" 
SOAP-ENV:encodingStyle="http://schemas.xmlsoap.org/soap/encoding/">
<SOAP-ENV:Body>
<ns1:getCitiesResponse>
<return xsi:type="xsd:string">
[
{
"cityTitle": "Тирана",
"countryId": "7",
"cityId": "2493",
"IATA": "TIA"
},
{
"cityTitle": "Ла-Романа",
"countryId": "48",
"cityId": "1280",
"IATA": "LRM"
},
{
"cityTitle": "Херсон",
"countryId": "145",
"cityId": "2719",
"IATA": "KHE"
},
{
"cityTitle": "Шарм",
"countryId": "49",
"cityId": "2851",
"IATA": "SSH"
}
]
</return>
</ns1:getCitiesResponse>
</SOAP-ENV:Body>
</SOAP-ENV:Envelope>

我正在尝试解析该响应。我想得到cityIdcountryId

XmlDocument listXML = new XmlDocument();
listXML.LoadXml(response);
string baseNode = @"return/";
XmlNode item1 = listXML.SelectSingleNode(baseNode + "countryId"); 
XmlNode item2 = listXML.SelectSingleNode(baseNode + "cityId");
string s = item1.InnerText.ToString();
string s1 = item2.InnerText.ToString();

但这是null;我该怎么办?

SOAP 响应的return元素包含一个 JSON 字符串,因此不能使用XmlDocument和 XPath 查询从中提取数据。

您需要使用 JSON 反序列化程序查询 JSON 数据,例如,我在此示例中使用了 JSON.NET - 您可以通过安装 NuGet 包 Newtonsoft.JSON 将其添加到项目中。

所以这里有两个步骤 - 首先从 XML 响应中提取return元素的内容。我使用XDocument而不是您使用的XmlDocument,因为XDocument是一个更现代的 API,并且与 Linq 等现代语言功能配合得更好。

第二步是反序列化 JSON 内容,并将内容提取为变量。

var xDoc = XDocument.Parse(response);
var returnJson = xDoc.Descendants("return")
.Single()
.Value;
var cities = JArray.Parse(returnJson);
foreach (var city in cities)
{
var cityId = city["cityId"].Value<string>();
var countryId = city["countryId"].Value<string>();
}

最新更新