HTMLspecialchars вызывает исчезнуть текст
-
13-12-2019 - |
Вопрос
Я столкнулся с определенной строкой (она не полностью печатается, но вы можете увидеть ее ниже), что заставляет HTMLSPECialChars () для возврата строки нулевой длины.Есть ли способ, которым это можно исправить?
$Stmnt = 'SELECT subject_name FROM bans WHERE id = 2321';
$Fetch = $Conn->query($Stmnt);
if(!$Fetch)
die('Could not query DB');
while($Row = $Fetch->fetch_array(MYSQLI_ASSOC))
{
$RawName = $Row['subject_name'];
$RawLen = strlen($RawName);
echo('RAW NAME: ['.$RawName.']'.', LENGTH: ['.$RawLen.']'.'<br />');
for($i = 0; $i < $RawLen; $i++)
echo('CHAR '.$i.' = ['.$RawName[$i].'] (ORD: '.ord($RawName[$i]).')<br />');
$CleanName = htmlspecialchars($RawName, ENT_QUOTES, 'UTF-8');
$CleanLen = strlen($CleanName);
echo('CLEAN NAME: ['.$CleanName.']'.', LENGTH: ['.$CleanLen.']'.'<br />');
for($i = 0; $i < $CleanLen; $i++)
echo('CHAR '.$i.' = ['.$CleanName[$i].'] (ORD: '.ord($CleanName[$i]).')<br />');
}
$Fetch->close();
echo('DONE');
.
Выход:
RAW NAME: [━═★ Coммander Fι5н �], LENGTH: [31]
CHAR 0 = [�] (ORD: 226)
CHAR 1 = [�] (ORD: 148)
CHAR 2 = [�] (ORD: 129)
CHAR 3 = [�] (ORD: 226)
CHAR 4 = [�] (ORD: 149)
CHAR 5 = [�] (ORD: 144)
CHAR 6 = [�] (ORD: 226)
CHAR 7 = [�] (ORD: 152)
CHAR 8 = [�] (ORD: 133)
CHAR 9 = [ ] (ORD: 32)
CHAR 10 = [C] (ORD: 67)
CHAR 11 = [o] (ORD: 111)
CHAR 12 = [�] (ORD: 208)
CHAR 13 = [�] (ORD: 188)
CHAR 14 = [�] (ORD: 208)
CHAR 15 = [�] (ORD: 188)
CHAR 16 = [a] (ORD: 97)
CHAR 17 = [n] (ORD: 110)
CHAR 18 = [d] (ORD: 100)
CHAR 19 = [e] (ORD: 101)
CHAR 20 = [r] (ORD: 114)
CHAR 21 = [ ] (ORD: 32)
CHAR 22 = [F] (ORD: 70)
CHAR 23 = [�] (ORD: 206)
CHAR 24 = [�] (ORD: 185)
CHAR 25 = [5] (ORD: 53)
CHAR 26 = [�] (ORD: 208)
CHAR 27 = [�] (ORD: 189)
CHAR 28 = [ ] (ORD: 32)
CHAR 29 = [�] (ORD: 226)
CHAR 30 = [�] (ORD: 148)
CLEAN NAME: [], LENGTH: [0]
DONE
. Решение
Я понимаю сейчас, почему он возвращает строку нулевой длины. Извините за то, что задал этот вопрос. Я должен был исследовать больше до публикации. В любом случае, ответ следующий:
на руководстве PHP Страница для htmlspecialchars :
Если входная строка содержит неверную последовательность блока кода в данной кодировании, будет возвращена пустая строка, если не установлены флаги INT_IGRORE или ENT_SUBSTITE.
Тогда я спрашиваю себя, что "недействителен" об этой строке? На Wiki Страница для UTF-8 это дает хорошую диаграмму UTF- 8 кодировкой. Все коды, представляющие «простой текст ASCII», будут 0-127 (MSB в байте всегда 0).
Если MSB байта составляет 1 (десятичный от 128 до 255), он сообщает анализатор совместимого UTF-8, что CodePoint состоит из многобайтовой цепи. и первые два самых значительных бита byte должны быть 1, а затем 0.
Очевидно, что в этой строке есть случай, когда один байт более 127, и следующий байт не начинается с 1 и 0. Поэтому он неверный кодировку UTF-8.
Спасибо за Это так сообщение Для разрешения, который, на мой взгляд, должен использовать флаг ent_substitute (или я полагаю, ent_ignore, если вы уверены, что удаление этих несоответствующих байтов не будет проблема безопасности ).