htmlentities

(PHP 3, PHP 4 , PHP 5)

htmlentities --  Convertit tous les caractères éligibles en entités HTML

Description

string htmlentities ( string string [, int quote_style [, string charset]] )

htmlentities est identique à la fonction htmlspecialchars(), sauf que tous les caractères qui ont des équivalents en entités HTML sont effectivement traduits.

Comme htmlspecialchars(), cette fonction prend un deuxième argument optionnel, qui indique comment doivent être traités les guillemets doubles et simples. Vous pouvez utiliser l'une des constantes suivantes la valeur par défaut étant ENT_COMPAT :

Tableau 1. Constantes disponibles pour quote_style

NomDescription
ENT_COMPATConvertit les guillemets doubles, et ignore les guillemets simples
ENT_QUOTESConvertit les guillemets doubles et les guillemets simples
ENT_NOQUOTESIgnore les guillemets doubles et les guillemets simples

Le support du paramètre optionnel quote a été ajouté en PHP 4.0.3.

Comme htmlspecialchars(), cette fonction prend un troisième argument optionnel qui définit le jeux de caractères utilisé durant la conversion. Le support de cet argument a été ajouté en PHP 4.1.0. Actuellement, le jeu de caractères ISO-8859-1 est utilisé par défaut.

Les jeux de caractères suivantes sont disponibles et supportés par PHP 4.3.0 et plus récent.

Tableau 2. Jeux de caractères supportés

Jeux de caractèresAliasDescription
ISO-8859-1ISO8859-1 Europe occidentale, Latin-1
ISO-8859-15ISO8859-15 Europe occidentale, Latin-9. Dispose du signe Euro, des caractères spéciaux français et finlandais, qui manque au Latin-1(ISO-8859-1).
UTF-8  Unicode 8 bits multi octets, compatible avec l'ASCII
cp866ibm866, 866 Jeux de caractères Cyrillic spécifique à DOS. Ce jeux de caractères est supporté depuis PHP 4.3.2.
cp1251Windows-1251, win-1251, 1251 Jeux de caractères Cyrillic spécifique à Windows. Ce jeux de caractères est supporté depuis PHP 4.3.2.
cp1252Windows-1252, 1252 Jeux de caractères spécifique de Windows pour l'Europe occidentale.
KOI8-Rkoi8-ru, koi8r Russe. Ce jeux de caractères est supporté depuis PHP 4.3.2.
BIG5950 Chinois traditionnel, principalement utilisé à Taiwan.
GB2312936 Chinois simplifié, officiel.
BIG5-HKSCS  Big5 avec les extensions de Hong Kong, chinois traditionnel.
Shift_JISSJIS, 932 Japonais
EUC-JPEUCJP Japonais

Note : Les autres jeux de caractères ne sont pas reconnus, et le ISO-8859-1 sera utilisé à la place.

Si vous voulez réaliser l'opération inverse, vous devez utiliser la fonction html_entity_decode().

Exemple 1. Exemple avec htmlentities()

<?php
$str
= 'Un \'apostrophe\' en <strong>gras</strong>';

// Affiche : Un 'apostrophe' en &lt;strong&gt;gras&lt;/strong&gt;
echo htmlentities($str);

// Affiche : Un &#039;apostrophe&#039; en &lt;strong&gt;gras&lt;/strong&gt;
echo htmlentities($str, ENT_QUOTES);
?>

Voir aussi html_entity_decode(), get_html_translation_table(), htmlspecialchars(), nl2br() et urlencode().