Wie gehe ich mit CDATA-Abschnitten richtig um, wenn ich SimpleXMLElement von PHP verwende?

DDD
Freigeben: 2024-11-19 22:33:02
Original
290 Leute haben es durchsucht

How to Properly Handle CDATA Sections When Using PHP's SimpleXMLElement?

Verarbeitung von CDATA in PHP mit SimpleXMLElement

Beim Parsen von XML-Dokumenten, die CDATA-Abschnitte enthalten, mit SimpleXMLElement können Nullwerte auftreten. So beheben Sie dieses Problem:

Zugriff auf CDATA-Inhalte

Ein fehlerhafter Zugriff auf CDATA-Inhalte kann zu Nullwerten führen. Um korrekt darauf zuzugreifen, können Sie entweder direkt aus dem SimpleXMLElement-Objekt ausgeben oder es in einen String umwandeln. Zum Beispiel:

$content = simplexml_load_string(
    '<content><![CDATA[Hello, world!]]></content>'
);

// Output content directly
echo (string) $content;

// Cast to string
echo $content;
Nach dem Login kopieren

LIBXML_NOCDATA-Option

Ein anderer Ansatz besteht darin, die LIBXML_NOCDATA-Option während der SimpleXMLElement-Erstellung zu verwenden. Diese Option weist den Parser an, CDATA-Abschnitte als Textknoten anstelle von CDATA-Abschnitten abzurufen. Hier ist ein Beispiel:

$content = simplexml_load_string(
    '<content><![CDATA[Hello, world!]]></content>'
    , null
    , LIBXML_NOCDATA
);

echo $content->content;
Nach dem Login kopieren

Das obige ist der detaillierte Inhalt vonWie gehe ich mit CDATA-Abschnitten richtig um, wenn ich SimpleXMLElement von PHP verwende?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage