在对字符串运行时,PHP函数strlen()和mb_strlen()都返回了错误的字符数。
这是我正在使用的一段代码...
$foo = mb_strlen($itemDetails['ITEMDESC'], 'UTF-8');
echo $foo;它告诉我这个刺痛-“4/2”直虹膜剪刀“是45个字符的长度。它是27。
它还告诉我,这个字符串-“婴儿脚后跟保温器,无胶粘附垫,100/cs”是54,这是正确的。
我假设这是一些字符编码的问题,我认为所有的东西都应该是UTF-8。我尝试过向mb_strlen()提供几种不同的字符编码类型,它们都返回包含这些非标准字符的字符串的奇怪计数。
我不知道为什么会发生这种事。
发布于 2011-07-06 07:31:05
仔细检查你的文本是否真的是UTF-8。这个“?”字符让我觉得这是一个典型的字符编码问题。您应该检查从文本的原点到您上面引用的代码中的点的整个路径,因为有很多地方的编码可能会被转换。
文本源自HTML表单吗?确保您的<form>元素包含accept-charset="UTF-8"属性。
在此过程中,文本是否存储在数据库中?确保数据库以UTF-8格式存储和返回数据。这意味着检查服务器的全局缺省值、数据库或模式的缺省值以及表本身。
发布于 2012-04-28 07:48:18
您的输入很可能是以UTF-16编码的。您可以转换为UTF-8
$foo = mb_strlen(mb_convert_encoding($itemDetails['ITEMDESC'], "UTF-8", "UTF-16"));
或者,如果您使用mb_strlen(),请确保使用正确的编码作为第二个参数。
$foo = mb_strlen($itemDetails['ITEMDESC'], "UTF-16");
如果没有正确的编码,mb_strlen将总是返回错误的结果。在处理UTF-8/16/32编码的字符串时,很容易陷入麻烦。mb_detect_encoding()不会解决这个问题。
https://stackoverflow.com/questions/6589666
复制相似问题