


Wie speichere ich HTML aus einem DOM-Dokument, ohne Elemente auf Blockebene zu verlieren?
So speichern Sie HTML eines DOM-Dokuments, ohne Elemente auf Blockebene wegzulassen
Das Problem tritt auf, wenn versucht wird, den Inhalt eines DOM-Dokuments als HTML zu speichern ohne die Standard-HTML-, Body- und P-Tag-Wrapper einzuschließen. Die vorgeschlagene Lösung der Verwendung von saveXML($d->getElementsByTagName('p')->item(0)) funktioniert nur, wenn dem Inhalt Elemente auf Blockebene fehlen.
Das Problem mit dem Ursprünglicher Ansatz
In Fällen, in denen Elemente auf Blockebene vorhanden sind, wie z. B. h1-Tags, wird die Ausgabe von saveXML abgeschnitten, sodass nur noch übrig bleibt der Text innerhalb des p-Tags.
Der aktualisierte Ansatz
Um dieses Problem zu beheben, können Sie eine aktualisierte Version der in PHP 5.4 und Libxml 2.6 eingeführten Funktion „loadHTML“ verwenden . Diese Funktion enthält einen $options-Parameter, mit dem Sie angeben können, wie der Inhalt analysiert werden soll. Durch Festlegen der folgenden Optionen:
$html->loadHTML($content, LIBXML_HTML_NOIMPLIED | LIBXML_HTML_NODEFDTD);
Erklärung der Optionen
- LIBXML_HTML_NOIMPLIED deaktiviert das automatische Hinzufügen implizierter HTML-/Body-Elemente.
- LIBXML_HTML_NODEFDTD verhindert, dass ein Standarddokumenttyp hinzugefügt wird, wenn dies nicht der Fall ist gefunden.
Wenn Sie anschließend saveHTML() ausführen, enthält die Ausgabe kein Doctype, HTML-Tag oder Body-Tag. Dieser Ansatz stellt sicher, dass Elemente auf Blockebene in der Ausgabe beibehalten werden.
Hinweis:
- In der Libxml 2.6-Dokumentation heißt es, dass Libxml 2.6 erforderlich ist, aber LIBXML_HTML_NODEFDTD ist nur in Libxml verfügbar 2.7.8.
- LIBXML_HTML_NOIMPLIED ist in Libxml 2.7.7 verfügbar.
Das obige ist der detaillierte Inhalt vonWie speichere ich HTML aus einem DOM-Dokument, ohne Elemente auf Blockebene zu verlieren?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Die Absolute -Sitzungs -Zeitlimit startet zum Zeitpunkt der Erstellung der Sitzung, während eine Zeitlimit in der Leerlaufsitzung zum Zeitpunkt der No -Operation des Benutzers beginnt. Das Absolute -Sitzungs -Zeitlimit ist für Szenarien geeignet, in denen eine strenge Kontrolle des Sitzungslebenszyklus erforderlich ist, z. B. finanzielle Anwendungen. Das Timeout der Leerlaufsitzung eignet sich für Anwendungen, die die Benutzer für lange Zeit aktiv halten, z. B. soziale Medien.

Der Serversitzungsausfall kann durch Befolgen der Schritte gelöst werden: 1. Überprüfen Sie die Serverkonfiguration, um sicherzustellen, dass die Sitzung korrekt festgelegt wird. 2. Überprüfen Sie die Client -Cookies, bestätigen Sie, dass der Browser es unterstützt und korrekt senden. 3. Überprüfen Sie die Speicherdienste wie Redis, um sicherzustellen, dass sie normal arbeiten. 4. Überprüfen Sie den Anwendungscode, um die korrekte Sitzungslogik sicherzustellen. Durch diese Schritte können Konversationsprobleme effektiv diagnostiziert und repariert werden und die Benutzererfahrung verbessert werden.

Session_Start () iscrucialinphPFormAnagingUSSERSIONS.1) ItinitiatesanewSessionifnoneExists, 2) Wiederaufnahmen und 3) setaSessionCookieforContinuityAcrossRequests, aktivierende Anwendungen wie

Das Festlegen des HTTPonly -Flags ist für Sitzungscookies von entscheidender Bedeutung, da es effektiv verhindern und die Informationen zur Benutzersitzung schützen kann. Insbesondere 1) Das Httponly -Flag verhindert, dass JavaScript auf Cookies zugreift, 2) Das Flag kann durch SetCookies eingestellt werden und in PHP und Flasche 3), obwohl es nicht von allen Angriffen von allen Angriffen verhindert werden kann, Teil der Gesamtsicherheitsrichtlinie sein sollte.

PhpSsionSsionSolvetheProblemofMaintainingStateAcrossmultipehttprequestsBoringDataontheserverandassociatingitittprequests.1) Sie starteten die Stundeataserver-Seite, typischerweise infileSordatabasen, undusaSasionIdinacookookookotenData

PHPSSIONS CANSTORESTRINGEN, ZUGNALTEN, ARRAYS, ANDOBjekte.1.

TostartaphpSession, useSession_start () atthescript'Sbeginning.1) PlaCEITBEFOREANYOUTPUTTOTHESESSIONSCOOKIE.2) useSsionsforuserDatalikeloginStatusOrShopingCarts

Die Sitzung der Sitzung bezieht sich auf die Generierung einer neuen Sitzungs -ID und die Ungültigmachung der alten ID, wenn der Benutzer sensible Vorgänge bei festgelegten Sitzungsangriffen ausführt. Die Implementierungsschritte umfassen: 1. Erkennen sensibler Vorgänge, 2. Erstellen neuer Sitzungs-ID, 3..


Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

Heiße Werkzeuge

SAP NetWeaver Server-Adapter für Eclipse
Integrieren Sie Eclipse mit dem SAP NetWeaver-Anwendungsserver.

Herunterladen der Mac-Version des Atom-Editors
Der beliebteste Open-Source-Editor

MantisBT
Mantis ist ein einfach zu implementierendes webbasiertes Tool zur Fehlerverfolgung, das die Fehlerverfolgung von Produkten unterstützen soll. Es erfordert PHP, MySQL und einen Webserver. Schauen Sie sich unsere Demo- und Hosting-Services an.

SublimeText3 Linux neue Version
SublimeText3 Linux neueste Version

ZendStudio 13.5.1 Mac
Leistungsstarke integrierte PHP-Entwicklungsumgebung
