PHPのにhtmlentities()関数
例
HTMLエンティティへの一部の文字:
<?php
$str = "<© W3CSch°°¦§>";
echo htmlentities($str);
?>
$str = "<© W3CSch°°¦§>";
echo htmlentities($str);
?>
(ソースを表示)を以下のように上記のコードのHTML出力は、次のとおりです。
<!DOCTYPE html>
<html>
<body>
<© W3CSçh°°¦§>
</body>
</html>
<html>
<body>
<© W3CSçh°°¦§>
</body>
</html>
次のように上記のコードのブラウザの出力は、次のとおりです。
<© W3CSch°°¦§>
実行中のインスタンス»
定義と使用法
htmlentities()関数は、HTMLエンティティに文字を変換します。
ヒント:バック文字にHTMLエンティティを入れ、使用がhtml_entity_decode()関数。
ヒント:使用get_html_translation_table()を使用するためにはhtmlentities()変換テーブルを返す関数。
文法
htmlentities( string,flags,character-set,double_encode )
参数 | 描述 |
---|---|
string | 必需。规定要转换的字符串。 |
flags | 可选。规定如何处理引号、无效的编码以及使用哪种文档类型。 可用的引号类型:
无效的编码:
规定使用的文档类型的附加 flags:
|
character-set | 可选。一个规定了要使用的字符集的字符串。 允许的值:
注释:在 PHP 5.4 之前的版本,无法被识别的字符集将被忽略并由 ISO-8859-1 替代。自 PHP 5.4 起,无法被识别的字符集将被忽略并由 UTF-8 替代。 |
double_encode | 可选。一个规定了是否编码已存在的 HTML 实体的布尔值。
|
技術的詳細
戻り値: | 変換された文字列を返します。 文字列が無効なコードが含まれている場合は、空の文字列がENT_IGNOREまたはENT_SUBSTITUTEフラグがない限り、返されます。 |
---|---|
PHPバージョン: | 4+ |
更新ログ: | UTF-8へのPHP 5では、デフォルト値の文字セットのパラメータ。 PHP 5.4では、コメントを追加しました:ENT_SUBSTITUTE、ENT_DISALLOWED、ENT_HTML401、ENT_HTML5、ENT_XML1とENT_XHTMLを。 PHP 5.3では、ENT_IGNOREを追加します。 PHP 5.2.3では、double_encodeパラメータを追加します。 PHP 4.1では、 文字セットのパラメータを追加します。 |
より多くの例
例1
HTMLエンティティへの一部の文字:
<?php
$str = "Jane & 'Tarzan'";
echo htmlentities($str, ENT_COMPAT); // Will only convert double quotes
echo "<br>";
echo htmlentities($str, ENT_QUOTES); // Converts double and single quotes
echo "<br>";
echo htmlentities($str, ENT_NOQUOTES); // Does not convert any quotes
?>
$str = "Jane & 'Tarzan'";
echo htmlentities($str, ENT_COMPAT); // Will only convert double quotes
echo "<br>";
echo htmlentities($str, ENT_QUOTES); // Converts double and single quotes
echo "<br>";
echo htmlentities($str, ENT_NOQUOTES); // Does not convert any quotes
?>
(ソースを表示)を以下のように上記のコードのHTML出力は、次のとおりです。
<!DOCTYPE html>
<html>
<body>
Jane & 'Tarzan'<br>
Jane & 'Tarzan'<br>
Jane & 'Tarzan'
</body>
</html>
<html>
<body>
Jane & 'Tarzan'<br>
Jane & 'Tarzan'<br>
Jane & 'Tarzan'
</body>
</html>
次のように上記のコードのブラウザの出力は、次のとおりです。
Jane & 'Tarzan'
Jane & 'Tarzan'
Jane & 'Tarzan'
Jane & 'Tarzan'
Jane & 'Tarzan'
実行中のインスタンス»
例2
西ヨーロッパの文字セットを使用することにより、一部の文字がHTMLエンティティに変換されます。
<?php
$str = "My name is Øyvind Åsane. I'm Norwegian.";
echo htmlentities($str, ENT_QUOTES, "ISO-8859-1"); // Will only convert double quotes (not single quotes), and uses the character-set Western European
?>
$str = "My name is Øyvind Åsane. I'm Norwegian.";
echo htmlentities($str, ENT_QUOTES, "ISO-8859-1"); // Will only convert double quotes (not single quotes), and uses the character-set Western European
?>
(ソースを表示)を以下のように上記のコードのHTML出力は、次のとおりです。
<!DOCTYPE html>
<html>
<body>
My name is Øyvind Åsane. I'm Norwegian.
</body>
</html>
<html>
<body>
My name is Øyvind Åsane. I'm Norwegian.
</body>
</html>
次のように上記のコードのブラウザの出力は、次のとおりです。
My name is Øyvind Åsane. I'm Norwegian.
実行中のインスタンス»
PHPの文字列リファレンス