html_entity_decode
(PHP 4 >= 4.3.0, PHP 5)
html_entity_decode — Konvertiert alle benannten HTML-Zeichen in ihre entsprechenden Ursprungszeichen
Beschreibung
html_entity_decode() ist das Gegenstück zu htmlentities(), das alle benannten HTML-Zeichen innerhalb von string in ihre entsprechenden Ursprungszeichen zurückwandelt.
Parameter Liste
- string
-
The input string.
- quote_style
-
Der optionale zweite Parameter quote_style lässt Ihnen die Entscheidung, was mit 'einfachen' und "doppelten" Anführungszeichen geschehen soll. Sie können eine der drei genannten Konstanten einsetzen, standardmäßig wird ENT_COMPAT verwendet:
Verfügbare quote_style -Konstanten Konstantenname Beschreibung ENT_COMPAT Konvertiert doppelte Anführungszeichen und lässt einfache Anführungszeichen unberührt. ENT_QUOTES Konvertiert sowohl doppelte als auch einfache Anführungszeichen. ENT_NOQUOTES Lässt sowohl doppelte als auch einfache Anführungszeichen unberührt. - charset
-
Die ISO-8859-1 Zeichentabelle wird standardmäßig als dritter Parameter charset verwendet. Dieser Parameter legt die Zeichentabelle fest, die der Konvertierung zugrunde gelegt wird.
Die folgenden Zeichensätze werden mit PHP 4.3.0 und höher unterstützt:
Unterstützte Zeichensätze Zeichensatz Alias Beschreibung ISO-8859-1 ISO8859-1 Westeuropäisch, Latin-1 ISO-8859-15 ISO8859-15 Westeuropäisch, Latin-9. Enthält das Euro-Zeichen sowie französische und finnische Buchstaben, die in Latin-1(ISO-8859-1) fehlen. UTF-8 ASCII-kompatibles Multi-Byte 8-Bit Unicode. cp866 ibm866, 866 DOS-spezifischer Kyrillischer Zeichensatz. Dieser Zeichensatz wird ab PHP Version 4.3.2 unterstützt. cp1251 Windows-1251, win-1251, 1251 Windows-spezifischer Kyrillischer Zeichensatz. Dieser Zeichensatz wird ab PHP Version 4.3.2 unterstützt. cp1252 Windows-1252, 1252 Windows spezifischer Zeichensatz für westeuropäische Sprachen. KOI8-R koi8-ru, koi8r Russisch. Dieser Zeichensatz wird ab PHP Version 4.3.2 unterstützt. BIG5 950 Traditionelles Chinesisch, hauptsächlich in Taiwan verwendet. GB2312 936 Vereinfachtes Chinesisch, nationaler Standard-Zeichensatz. BIG5-HKSCS Big5 mit Hongkong-spezifischen Erweiterungen; traditionelles Chinesisch. Shift_JIS SJIS, 932 Japanisch EUC-JP EUCJP Japanisch Hinweis: Weitere Zeichensätze sind nicht implementiert, an ihrer Stelle wird ISO-8859-1 verwendet.
Rückgabewerte
Gibt die dekodierte Zeichenkette zurück.
ChangeLog
Version | Beschreibung |
---|---|
5.0.0 | Die Unterstützung für Multibyte-Zeichensätze wurde hinzugefügt. |
Beispiele
Example#1 Dekodieren benannter HTML-Zeichen
<?php
$orig = "I'll \"walk\" the <b>dog</b> now";
$a = htmlentities($orig);
$b = html_entity_decode($a);
echo $a; // I'll "walk" the <b>dog</b> now
echo $b; // I'll "walk" the <b>dog</b> now
// Usern mit einer PHP-Version vor 4.3.0 hilft folgender Workaround:
function unhtmlentities($string)
{
// replace numeric entities
$string = preg_replace('~&#x([0-9a-f]+);~ei', 'chr(hexdec("\\1"))', $string);
$string = preg_replace('~&#([0-9]+);~e', 'chr("\\1")', $string);
// replace literal entities
$trans_tbl = get_html_translation_table(HTML_ENTITIES);
$trans_tbl = array_flip($trans_tbl);
return strtr($string, $trans_tbl);
}
$c = unhtmlentities($a);
echo $c; // I'll "walk" the <b>dog</b> now
?>
Anmerkungen
Hinweis: Sie wundern sich vielleicht, warum trim(html_entity_decode(' ')); den String nicht zu einem leeren Sting reduziert. Der Grund ist darin zu finden, dass ' ' nicht dem Zeichen mit ASCII-Code 32 entspricht (dieser wird von trim() entfernt), sondern dem Zeichen mit ASCII-Code 160 (0xa0) in der Standard-Zeichentabelle ISO 8859-1.