Ho questo brutto XML che ha un sacco di spazi dei nomi su di esso, quando provo a caricarlo con simpleXML se indico il primo spazio dei nomi otterrei un oggetto xml, ma i seguenti tag con altri spazi dei nomi non potrebbe arrivare all'oggetto.analizza un XML con SimpleXML che ha più spazi dei nomi
Come analizzare questo XML?
<?xml version="1.0" encoding="UTF-8"?>
<soap-env:Envelope xmlns:soap-env="http://schemas.xmlsoap.org/soap/envelope/">
<soap-env:Header>
<eb:MessageHeader xmlns:eb="http://www.ebxml.org/namespaces/messageHeader" eb:version="1.0" soap-env:mustUnderstand="1">
<eb:From>
<eb:PartyId eb:type="URI">wscompany.com</eb:PartyId>
</eb:From>
<eb:To>
<eb:PartyId eb:type="URI">mysite.com</eb:PartyId>
</eb:To>
<eb:CPAId>something</eb:CPAId>
<eb:ConversationId>moredata.com</eb:ConversationId>
<eb:Service eb:type="compXML">theservice</eb:Service>
<eb:Action>theaction</eb:Action>
<eb:MessageData>
<eb:MessageId>a certain messageid</eb:MessageId>
<eb:Timestamp>2009-04-11T18:43:58</eb:Timestamp>
<eb:RefToMessageId>mid:areference</eb:RefToMessageId>
</eb:MessageData>
</eb:MessageHeader>
<wsse:Security xmlns:wsse="http://schemas.xmlsoap.org/ws/2002/12/secext">
<wsse:BinarySecurityToken valueType="String" EncodingType="wsse:Base64Binary">an impresive binary security toekn</wsse:BinarySecurityToken>
</wsse:Security>
</soap-env:Header>
<soap-env:Body>
<SessionCreateRS xmlns="http://www.opentravel.org/OTA/2002/11" version="1" status="Approved">
<ConversationId>the goodbye token</ConversationId>
</SessionCreateRS>
</soap-env:Body>
</soap-env:Envelope>
im cercando di analizzarlo con il seguente codice
<?php
$xml = simplexml_load_string($res,NULL,NULL,"http://schemas.xmlsoap.org/soap/envelope/");
?>
ma l'oggetto $ xml sarebbe solo contenere le seguenti
SimpleXMLElement Object
(
[Header] => SimpleXMLElement Object
(
)
[Body] => SimpleXMLElement Object
(
)
)
Semplicemente brillian non solo mi ha aiutato a risolvere il mio problema, ma anche chiarito come XPath lavorato :) grazie! – perrohunter
Non è necessario passare a XPath solo perché si utilizzano gli spazi dei nomi. – IMSoP
Se si utilizza XPath, è necessario registrare gli spazi dei nomi in modo esplicito come nel codice precedente, altrimenti si verifica un errore. – Bobulous