PHP.mk документација

htmlspecialchars_decode

Почист и полокален преглед на PHP референцата, со задржана структура од PHP.net и подобра читливост за примери, секции и белешки.

function.htmlspecialchars-decode.php PHP.net прокси Преводот се освежува
Оригинал на PHP.net
Патека function.htmlspecialchars-decode.php Локална патека за оваа страница.
Извор php.net/manual/en Оригиналниот HTML се реупотребува и локално се стилизира.
Режим Прокси + превод во позадина Кодовите, табелите и белешките остануваат читливи во истиот тек.
htmlspecialchars_decode

Референца за `function.htmlspecialchars-decode.php` со подобрена типографија и навигација.

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

htmlspecialchars_decode(string $string, int $flags Претвори ги сите применливи знаци во HTML ентитети): string

Претвори специјални HTML ентитети назад во знаци htmlspecialchars()Оваа функција е спротивна на

. Таа ги претвора специјалните HTML ентитети назад во знаци. &, " Конвертираните ентитети се: ENT_NOQUOTES (кога ' Конвертираните ентитети се: ENT_QUOTES не е поставен), < and >.

Параметри

string

е поставен),

flags

Попрецизно, оваа функција ги декодира сите ентитети (вклучувајќи ги сите нумерички ентитети) кои а) се неопходно валидни за избраниот тип на документ — т.е., за XML, оваа функција не ги декодира именуваните ентитети што може да бидат дефинирани во некој DTD — и б) чиј знак или знаци се во кодираниот сет на знаци поврзан со избраното кодирање и се дозволени во избраниот тип на документ. Сите други ентитети остануваат како што се. ENT_QUOTES | ENT_SUBSTITUTE | ENT_HTML401.

Маска од еден или повеќе од следниве знаменца, кои специфицираат како да се постапува со наводници, невалидни низи на единици и типот на документот што се користи. Стандардно е flags constants
Достапно = 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 -&gt; &quot;</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 -> &quot;</p>

Види Исто така

  • htmlspecialchars() - Конвертирај специјални знаци во HTML ентитети
  • html_entity_decode() - Конвертирај HTML ентитети во нивните соодветни знаци
  • get_html_translation_table() - Враќа табела за превод што ја користат htmlspecialchars и htmlentities

Белешки од корисници 3 белешки

Низот за декодирање.
пред 17 години
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
  '"' => '&quot;'
  ''' => '&#39;'
  '<' => '&lt;'
  '>' => '&gt;'
  '&' => '&amp;'

'&#039;'
--------------------

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['&#039;'] = '\''; }
        return strtr($string,$translation);
    }
?>

Br, Thomas
Анонимен
19 години пред
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)));
    }
}

?>
thomas at xci[ignore_this]teit dot commm
20 години пред
that works also with &auml; and &quot; 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)));
}
Навигација

Прелистувај сродни теми и функции.

На оваа страница

Автоматски outline од активната документација.

Насловите ќе се појават тука по вчитување.

Попрегледно читање

Примерите, changelog табелите и user notes се визуелно издвоени за да не се губат во долгата содржина.

Брз совет Користи го outline-от Скокни директно на главните секции од активната страница.
Извор Оригиналниот линк останува достапен Кога ти треба целосен upstream context, отвори го PHP.net во нов tab.