我正在尝试将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>
我正在尝试解析该响应。我想得到cityId
和countryId
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>();
}