Как разобрать ответ xml из поста в vb.net - PullRequest
1 голос
/ 12 октября 2011

Я отправляю на сайт, чтобы получить данные обратно. Сайт возвращает его в формате XML. Я могу получить данные в строку. Но я действительно хочу, чтобы каждый элемент в xml находился в отдельном строковом поле.

Sub lookup(ByVal Source As Object, ByVal e As EventArgs)
  Dim wData As String
  wData = WRequest("http://PostToThisSite.com", "POST","str=31&Password=pn&UserID=Q&Postcode="+txtPcode.Text)       
  Response.Write(wData)
End Sub

Function WRequest(URL As String, method As String, POSTdata As String) As String
    Dim responseData As String = ""
      Try
        Dim hwrequest As Net.HttpWebRequest = Net.Webrequest.Create(URL)
        hwrequest.Accept = "*/*"
        hwrequest.AllowAutoRedirect = true
        hwrequest.UserAgent = "http_requester/0.1"
        hwrequest.Timeout = 60000
        hwrequest.Method = method
        If hwrequest.Method = "POST" Then
          hwrequest.ContentType = "application/x-www-form-urlencoded"
          Dim encoding As New Text.ASCIIEncoding() 'Use UTF8Encoding for XML requests
          Dim postByteArray() As Byte = encoding.GetBytes(POSTdata)
          hwrequest.ContentLength = postByteArray.Length
          Dim postStream As IO.Stream = hwrequest.GetRequestStream()
          postStream.Write(postByteArray, 0, postByteArray.Length)
          postStream.Close()
        End If
        Dim hwresponse As Net.HttpWebResponse = hwrequest.GetResponse()
        If hwresponse.StatusCode = Net.HttpStatusCode.OK Then
          Dim responseStream As IO.StreamReader = _
            New IO.StreamReader(hwresponse.GetResponseStream())
          responseData = responseStream.ReadToEnd()
        End If
        hwresponse.Close()
        Catch e As Exception
          responseData = "An error occurred: " & e.Message
        End Try
      Return responseData
End Function

Приведенный выше код работает и записывает строку ...

Some Road City LU1 5QG

Возвращаемое значение XML: ..

<Address xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://site.co.uk/">
  <strOrganisation /> 
  <strProperty /> 
  <strStreet>Some Road</strStreet> 
  <strLocality /> 
  <strTown>City</strTown> 
  <strCounty /> 
  <strPostcode>LU1 5QG</strPostcode> 
  <strDPS /> 

Я хочу иметь возможность разделить эти поля и установить для них различные текстовые поля на странице ... справка?

Ответы [ 2 ]

2 голосов
/ 12 октября 2011

Загрузите строку XML в XmlDocument и извлеките значения с помощью XPath :

Dim doc = new XmlDocument()
doc.LoadXml(yourXmlString)
Dim nsm = new XmlNamespaceManager(doc.NameTable)
nsm.AddNamespace("a", "http://site.co.uk/")
txtStreet.Text = doc.SelectSingleNode("/a:Address/a:strStreet", nsm).InnerText

Вот рабочий фрагмент:

Dim doc = New XmlDocument()
doc.LoadXml("<Address xmlns:xsd=""http://www.w3.org/2001/XMLSchema"" xmlns:xsi=""http://www.w3.org/2001/XMLSchema-instance"" xmlns=""http://site.co.uk/""><strOrganisation /> <strProperty /> <strStreet>Some Road</strStreet> <strLocality /> <strTown>City</strTown> <strCounty /> <strPostcode>LU1 5QG</strPostcode><strDPS /></Address>")
Dim nsm = New XmlNamespaceManager(doc.NameTable)
nsm.AddNamespace("a", "http://site.co.uk/")
Dim streetValue = doc.SelectSingleNode("/a:Address/a:strStreet", nsm).InnerText

Несколько замечаний:

  1. Для поиска в XPath, если ваш xml имеет пространство имен, вам нужно добавить его в XmlNameSpaceManager создан из вашей таблицы имен XmlDocument .
  2. Если вы не хотите беспокойство об этом, вы можете пройтись по коллекциям узлов вручную через doc.ChildNodes[0].ChildNodes[0] и т. Д.
1 голос
/ 13 сентября 2013

Или попробуйте это, как я полагаю, автор спрашивал.

'Использовать XML Reader

        Dim xmlDoc = New XmlDocument
        Dim xmlNode As Xml.XmlNode
        xmlDoc.LoadXml(strResponse)

        xmlNode = xmlDoc.SelectSingleNode("//" + "strStreet")

        If Not xmlNode Is Nothing Then
            Dim Street = xmlNode.InnerText
        End If
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...