尽管每个
这将产生类似以下的输出:
ISO-8859
字符集被列为单独的编码,但mbstring函数会将每个ISO-8859
字符集视为可互换使用。为了更加明确:$strings = [
'English' => 'Ea vim decore sapientem repudiandae. Sea cu delenit gamu mutn, tic.',
'Cyrillic' => 'Лорем ипсум долор сит амет, ин ехерци вереар номинати яуи, сит ин омниум инермис но.',
'Greek' => 'Λορεμ ιπσθμ δολορ σιτ αμετ, ηασ γραεcο νθσqθαμ cθ, εστ θτ εσσε διcαμ qθαλισqθε cθ.',
'Armenian' => 'լոռեմ իպսում դոլոռ սիթ ամեթ, եամ նո թաթիոն ծոմպռեհենսամ, իուս ադ նիսլ ոմնիս մինիմ եսթ',
'Georgian' => 'ლორემ იფსუმ დოლორ სით ამეთ, ეხ ყუანდო ცოფიოსაე უსუ, იუს ეუ ჰინც ვერო დომინგ ჰის',
'Hindi' => 'वर्ष एसेएवं व्याख्यान संदेश होने लक्षण एसेएवं पहोचाना विचरविमर्श? वर्णन करती आशाआपस अन्तरराष्ट्रीयकरन. रहारुप कार्यसिधान्त',
'Korean' => '모든 국민은 보건에 관하여 국가의 보호를 받는다, 전직대통령의 신분과 예우에 관하여는 법',
'Arabic' => 'مع لهذه الهجوم عدم, فكان اتفاق الصفحات من أسر. وجزر عُقر أما بـ, عل دار بقسوة المتّبعة بالولايات. وإقامة والفرنسي كل لكل. أي',
'Hebrew' => 'עמוד מדינות, חפש ואלקטרוניקה אנתרופולוגיה דת, מה קהילה הקהילה טכנו'
];
$encodings = ['ISO-8859-1', 'ISO-8859-2', 'ISO-8859-3', 'ISO-8859-4', 'ISO-8859-5', 'ISO-8859-6', 'ISO-8859-7', 'ISO-8859-8', 'ISO-8859-9', 'ISO-8859-10', 'ISO-8859-13', 'ISO-8859-14', 'ISO-8859-15' ];
foreach( $strings as $lang => $text ) {
echo $lang . " is encoded as " . mb_detect_encoding( $text, $encodings ) . "\n";
foreach( $encodings as $encoding ) {
echo " - is " . (mb_check_encoding( $text, $encoding ) ? "" : "not ") . $encoding . "\n";
}
}
这将产生类似以下的输出:
Hindi is encoded as ISO-8859-1
- is ISO-8859-1
- is ISO-8859-2
- is ISO-8859-3
- is ISO-8859-4
- is ISO-8859-5
- is ISO-8859-6
- is ISO-8859-7
- is ISO-8859-8
- is ISO-8859-9
- is ISO-8859-10
- is ISO-8859-13
- is ISO-8859-14
- is ISO-8859-15
使用相同的所有列出语言生成相同的结果,这显然是错误的。
为什么mbstring单独列出每个ISO-8859
编码,但对它们进行可互换处理?是否有可靠的方法来检测正确的规范?
还是我只是误用了这些函数?
mb_detect_encoding
猜测编码方式,但这种猜测并不准确(而且该函数也没有太多尝试去做),而mb_check_encoding
只是告诉你一个字符串是否由给定编码的字节序列组成。 - user3942918mb_detect_encoding
,它没有任何价值,只会让人感到困惑。 - user3942918