PHP html_entity_decode() fonksiyonu

Örnek

HTML entitelerini karakterlere dönüştürme:

<?php
$str = "<© W3Sçh°°¦§>";
echo html_entity_decode($str);
?>

Yukarıdaki kodun HTML çıktısı şu şekildedir (kaynak kodunu görüntüle):

<!DOCTYPE html>
<html>
<body>
<? W3S?h????>
</body>
</html>

Yukarıdaki kodun tarayıcı çıktısı:

<? W3S?h????>

Tanım ve Kullanım

html_entity_decode() fonksiyonu HTML entiteleri karakterlere dönüştürür.

html_entity_decode() fonksiyonu htmlentities() Fonksiyonun tersi.

Sözdizimi

html_entity_decode(string,flags,character-set)
Parametre Açıklama
string Gerekli. Çözülmesi gereken dizge belirlenir.
flags

Opsiyonel. Çember içi işaretlerinin nasıl işleneceği ve hangi doküman türünün kullanılacağını belirler.

Kullanılabilir çember içi işaret türleri:

  • ENT_COMPAT -Varsayılan. Sadece çift çember içi işaretini çözür.
  • ENT_QUOTES - Çift ve tek çember içi işaretlerini çözür.
  • ENT_NOQUOTES - Hiçbir çember içi işaretini çözmez.

Kullanılan doküman türünün ek flags belirlenmesi:

  • ENT_HTML401 -Varsayılan. HTML 4.01 olarak işlenir.
  • ENT_HTML5 - HTML 5 olarak işlenir.
  • ENT_XML1 - XML 1 olarak işlenir.
  • ENT_XHTML - XHTML olarak işlenir.
character-set

Opsiyonel. String değeri, kullanılacak karakter seti belirlenir.

İzin verilen değerler:

  • UTF-8 -Varsayılan. ASCII ile uyumlu çok baytli 8 baytlık Unicode
  • ISO-8859-1 - Batı Avrupa
  • ISO-8859-15 - Batı Avrupa (Avro sembollü ISO-8859-1'te kaybolan Fransızca ve Fince harfleri eklendi)
  • cp866 - DOS'a özel Kiril karakter seti
  • cp1251 - Windows'a özel Kiril karakter seti
  • cp1252 - Windows'a özel Batı Avrupa karakter seti
  • KOI8-R - Rusça
  • BIG5 - Geleneksel Çince, öncelikle Tayvan'da kullanılır
  • GB2312 - Basit Çince, ulusal karakter seti
  • BIG5-HKSCS - Hong Kong genişletilmiş Big5
  • Shift_JIS - Japonca
  • EUC-JP - Japonca
  • MacRoman - Mac işletim sistemi tarafından kullanılan karakter seti

Yorum:PHP 5.4 öncesi sürümlerde, tanınmayan karakter setleri ISO-8859-1 ile değiştirilir ve göz ardı edilir. PHP 5.4'ten itibaren, tanınmayan karakter setleri UTF-8 ile değiştirilir ve göz ardı edilir.

Teknik ayrıntılar

Dönüş değeri: Dönüştürülen dizgeyi döndürür
PHP sürümü: 4.3.0+

Güncelleme günlüğü:

Sürüm Açıklama
PHP 5 character-set Parametrelerin varsayılan değeri UTF-8 olarak değiştirildi.
PHP 5.4

Yeni eklenen flags, çeviri tablolarının适用的文档类型 belirlenmesi için:

  • ENT_HTML401
  • ENT_HTML5
  • ENT_XML1
  • ENT_XHTML
PHP 5.3.4 Çok bayt kodlama desteği eklendi.

Daha fazla örnek

Örnek 1

HTML entitelerini karakterlere dönüştürme:

<?php
$str = "Bill & 'Steve'";
echo html_entity_decode($str, ENT_COMPAT); // Sadece çift tırnakları dönüştürür
echo "<br>";
echo html_entity_decode($str, ENT_QUOTES); // Çift ve tek tırnakları dönüştürür
echo "<br>";
echo html_entity_decode($str, ENT_NOQUOTES); // Hiçbir quoted işareti dönüştürmez
?>

Yukarıdaki kodun HTML çıktısı (Kaynak kodunu görüntüle):

<!DOCTYPE html>
<html>
<body>
Bill & 'Steve'<br>
Bill & 'Steve'<br>
Bill & 'Steve'
</body>
</html>

Yukarıdaki kodun tarayıcı çıktısı:

Bill & 'Steve'
Bill & 'Steve'
Bill & 'Steve'

Örnek 2

Batı Avrupa karakter kümesinin kullanılarak HTML entiteleri karakterlere dönüştürülür:

<?php
$str = "My name is Øyvind Åsane. I'm Norwegian.";
echo html_entity_decode($str, ENT_QUOTES, "ISO-8859-1");
?>

Yukarıdaki kodun HTML çıktısı (Kaynak kodunu görüntüle):

<!DOCTYPE html>
<html>
<body>
Adım ?yvind ?sane. Norveçlidir.
</body>
</html>

Yukarıdaki kodun tarayıcı çıktısı:

Adım ?yvind ?sane. Norveçlidir.