0

我正在尝试将一些 XML 提取到旧站点的经典 ASP 中。

我可以使它适用于一个示例,但不能适用于另一个示例。我想知道是否有人可以让我知道我需要做什么才能让它们都运行。提前致谢。

工作示例

Dim o2, oXML2
Set oXML2 = Server.CreateObject("Msxml2.DOMDocument.6.0")
Set o2 = Server.CreateObject("Msxml2.ServerXMLHTTP.6.0")
o2.open "GET", "https://api.eveonline.com/eve/CharacterID.xml.aspx?names=BorisKarlov", False
o2.send


xml2 = o2.responseText
oXML2.LoadXML xml2

response.Write oXML2.selectSingleNode("//currentTime").Text

失败的例子

Dim o, oXML
Set oXML = Server.CreateObject("Msxml2.DOMDocument.6.0")
Set o = Server.CreateObject("Msxml2.ServerXMLHTTP.6.0")
o.open "GET", "http://api.freelancer.com/User/Properties.xml?id=sulung81", False
o.send

xml = o.responseText
oXML.LoadXML xml

response.Write oXML.selectSingleNode("//url").Text
4

1 回答 1

1

失败的示例有一个 XML 命名空间集 ( xmlns="http://api.freelancer.com/schemas/xml-0.1")。

此文件中的所有元素都在该名称空间中。选择节点时必须使用它。

Dim oXML, node
Set oXML = Server.CreateObject("Msxml2.DOMDocument.6.0")

oXML.load "http://api.freelancer.com/User/Properties.xml?id=sulung81"
oXML.setProperty "SelectionNamespaces", "xmlns:fl='http://api.freelancer.com/schemas/xml-0.1'"

Set node = oXML.selectSingleNode("/fl:profile/fl:url")

If Not node Is Nothing
    Response.Write node.Text
End If

笔记

  • 您可以使用.load()方法直接从 URL 加载文件。不需要额外的ServerXMLHTTP对象。
  • 总是检查结果selectSingleNode()- 它可能是Nothing
  • 您也应该测试解析错误
  • 您必须使用命名空间前缀,即使文档没有使用。只要命名空间 URI 匹配,您就可以选择任何您喜欢的前缀。对于这个例子,我选择了fl.
  • 使用特定的 XPath 表达式。/fl:profile/fl:url好于//fl:url
于 2013-11-14T15:57:24.003 回答