The example for "htmlspecialchars_decode()" below sadly does not work for all PHP4 versions.
Quote from the PHP manual:
"get_html_translation_table() will return the translation table that is used internally for htmlspecialchars() and htmlentities()."
But it does NOT! At least not for PHP version 4.4.2.
This was already reported in a bug report (http://bugs.php.net/bug.php?id=25927), but it was marked as BOGUS.
Proof:
Code:
--------------------
<?php
var_dump(get_html_translation_table(HTML_SPECIALCHARS,ENT_QUOTES));
var_dump(htmlspecialchars('\'',ENT_QUOTES));
?>
--------------------
Output:
--------------------
array
'"' => '"'
''' => '''
'<' => '<'
'>' => '>'
'&' => '&'
'''
--------------------
This comment now is not to report this bug again (though I really believe it is one), but to complete the example and warn people of this pitfall.
To make sure your htmlspecialchars_decode fake for PHP4 works, you should do something like this:
<?php
function htmlspecialchars_decode($string,$style=ENT_COMPAT)
{
$translation = array_flip(get_html_translation_table(HTML_SPECIALCHARS,$style));
if($style === ENT_QUOTES){ $translation['''] = '\''; }
return strtr($string,$translation);
}
?>
Br, Thomashtmlspecialchars_decode
Почист и полокален преглед на PHP референцата, со задржана структура од PHP.net и подобра читливост за примери, секции и белешки.
htmlspecialchars_decode
Референца за `function.htmlspecialchars-decode.php` со подобрена типографија и навигација.
htmlspecialchars_decode
(PHP 5 >= 5.1.0, PHP 7, PHP 8)
htmlspecialchars_decode — (PHP 5 >= 5.1.0, PHP 7, PHP 8)
= NULL
$string, int $flags Претвори ги сите применливи знаци во HTML ентитети): stringПретвори специјални HTML ентитети назад во знаци htmlspecialchars()Оваа функција е спротивна на
. Таа ги претвора специјалните HTML ентитети назад во знаци. &,
" Конвертираните ентитети се: ENT_NOQUOTES (кога
' Конвертираните ентитети се: ENT_QUOTES не е поставен),
< and >.
Параметри
string-
е поставен),
flags-
Попрецизно, оваа функција ги декодира сите ентитети (вклучувајќи ги сите нумерички ентитети) кои а) се неопходно валидни за избраниот тип на документ — т.е., за XML, оваа функција не ги декодира именуваните ентитети што може да бидат дефинирани во некој DTD — и б) чиј знак или знаци се во кодираниот сет на знаци поврзан со избраното кодирање и се дозволени во избраниот тип на документ. Сите други ентитети остануваат како што се.
ENT_QUOTES | ENT_SUBSTITUTE | ENT_HTML401.Маска од еден или повеќе од следниве знаменца, кои специфицираат како да се постапува со наводници, невалидни низи на единици и типот на документот што се користи. Стандардно е flagsconstantsДостапно = NULL ENT_COMPATИме на константа ENT_QUOTESЌе ги претвори двојните наводници и ќе ги остави единечните наводници недопрени. ENT_NOQUOTESЌе ги претвори и двојните и единечните наводници. ENT_SUBSTITUTE(поголемо од) ENT_HTML401Замени ги невалидните точки на код за дадениот тип на документ со Unicode Replacement Character U+FFFD (UTF-8) или &#FFFD; (инаку) наместо да ги остави како што се. Ова може да биде корисно, на пример, за да се обезбеди исправност на XML документи со вградена надворешна содржина. ENT_XML1Ракувај со кодот како HTML 4.01. ENT_XHTMLРакувај со кодот како XML 1.0. ENT_HTML5Битови маски од една или повеќе од следниве знаменца, кои специфицираат како да се постапува со наводници и кој тип на документ да се користи. Стандардно е
Вратени вредности
EUCJP, eucJP-win
Дневник на промени
| Верзија | = NULL |
|---|---|
| 8.1.0 |
flags Пример #2 Употреба на ENT_COMPAT to ENT_QUOTES | ENT_SUBSTITUTE | ENT_HTML401.
|
Примери
ако е овозможен колекторот за отпадоци, htmlspecialchars_decode() example
<?php
$str = "<p>this -> "</p>\n";
echo htmlspecialchars_decode($str);
// note that here the quotes aren't converted
echo htmlspecialchars_decode($str, ENT_NOQUOTES);
?>Пример #1 Пример што покажува затворачка ознака што го опфаќа последниот нов ред
<p>this -> "</p> <p>this -> "</p>
Види Исто така
- htmlspecialchars() - Конвертирај специјални знаци во HTML ентитети
- html_entity_decode() - Конвертирај HTML ентитети во нивните соодветни знаци
- get_html_translation_table() - Враќа табела за превод што ја користат htmlspecialchars и htmlentities
Белешки од корисници 3 белешки
This should be the best way to do it.
(Reposted because the other one seems a bit slower and because those who used the code under called it htmlspecialchars_decode_php4)
<?php
if ( !function_exists('htmlspecialchars_decode') )
{
function htmlspecialchars_decode($text)
{
return strtr($text, array_flip(get_html_translation_table(HTML_SPECIALCHARS)));
}
}
?>that works also with ä and " and so on.
get_html_translation_table(HTML_ENTITIES) => offers more characters than HTML_SPECIALCHARS
function htmlspecialchars_decode_PHP4($uSTR)
{
return strtr($uSTR, array_flip(get_html_translation_table(HTML_ENTITIES, ENT_QUOTES)));
}