parsing SOAP XML response with php

前端 未结 2 1495
后悔当初
后悔当初 2021-01-06 23:13

I have checked multiple examples and the w3Schools tutorial but I can\'t figure out the structure of the SOAP response. I haven\'t touch php/xml in more than 10 years so you

相关标签:
2条回答
  • 2021-01-07 00:00

    The problem here is that your attribute has a namespace, so you need to register the ns with SimpleXML XPath and use it in your XPath query.

    This element declares two namespaces for its descendants:

    <diffgr:diffgram 
        xmlns:msdata="urn:schemas-microsoft-com:xml-msdata"
        xmlns:diffgr="urn:schemas-microsoft-com:xml-diffgram-v1">
    

    To register those namespaces with SimpleXML, you need to use the function registerXPathNamespace. Depending on what other queries you're doing, you might want to register both namespaces. For your query, you need the urn:schemas-microsoft-com:xml-diffgram-v1 (diffgr) namespace; register it like so:

    $sxe = new SimpleXMLElement($your_xml_here);
    $sxe->registerXPathNamespace('d', 'urn:schemas-microsoft-com:xml-diffgram-v1');
    

    Now you can access any element or attribute in the diffgr namespace by prefixing it with the letter d. Here's an example using the Table element with id Table1:

    $tables = $sxe->xpath('//Table[@d:id="Table1"]');
    foreach ($tables as $t) {
        echo $t->ProductSequence . PHP_EOL;
    }
    

    Output:

    A1999
    
    0 讨论(0)
  • 2021-01-07 00:09
    retrieve value from this type response 
    
    
    
    <?xml version="1.0" encoding="utf-8"?>
        <soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
            <soap:Body>
                <xyzResponse xmlns="http://tempuri.org/">
                    <xyzResult>
                        <xs:schema id="NewDataSet" xmlns="" xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:msdata="urn:schemas-microsoft-com:xml-msdata">
                            <xs:element name="NewDataSet" msdata:IsDataSet="true" msdata:UseCurrentLocale="true">
                                <xs:complexType>
                                    <xs:choice minOccurs="0" maxOccurs="unbounded">
                                        <xs:element name="Table">
                                            <xs:complexType>
                                                <xs:sequence>
                                                    <xs:element name="myCityID" type="xs:int" minOccurs="0" />
                                                    <xs:element name="myCityName" type="xs:string" minOccurs="0" />
    
                                                    <xs:element name="myLat" type="xs:double" minOccurs="0" />
                                                    <xs:element name="myLon" type="xs:double" minOccurs="0" />
                                                </xs:sequence>
                                            </xs:complexType>
                                        </xs:element>
                                    </xs:choice>
                                </xs:complexType>
                            </xs:element>
                        </xs:schema>
                        <diffgr:diffgram xmlns:msdata="urn:schemas-microsoft-com:xml-msdata" xmlns:diffgr="urn:schemas-microsoft-com:xml-diffgram-v1">
                            <NewDataSet xmlns="">
                                <Table diffgr:id="Table1" msdata:rowOrder="0">
                                    <CityID>1</CityID>
                                    <CityName>Ahmedabad</CityName>
                                    <Lat>23.045839</Lat>
                                    <Lon>72.550578</Lon>
                                </Table>
                                <Table diffgr:id="Table2" msdata:rowOrder="1">
                                    <CityID>21</CityID>
                                    <CityName>Amritsar</CityName>
                                    <Lat>31.705603</Lat>
                                    <Lon>74.807337</Lon>
                                </Table>
                            </NewDataSet>
                        </diffgr:diffgram>
                    </xyzResult>
                </xyzResponse>
            </soap:Body>
        </soap:Envelope>
    

    using this code you can easily get all the Tables data in $title variable and using that you can easily get any specific value easily...

                    $sxe = new SimpleXMLElement($response);
                    $sxe->registerXPathNamespace('d', 'urn:schemas-microsoft-com:xml-diffgram-v1');
                    $result = $sxe->xpath("//NewDataSet");
                    echo "<pre>";
                    //print_r($result[0]);
                    foreach ($result[0] as $title) {
                        print_r($title);
    
                    }
    
    0 讨论(0)
提交回复
热议问题