我在使用PHP将ISO-8859-1数据库内容转换为UTF-8时遇到一些问题。我正在运行以下代码进行测试:
// Connect to a latin1 charset database
// and retrieve "Georgia OâKeeffe", which contains a "â" character
$connection = mysql_connect('*****', '*****', '*****');
mysql_select_db('*****', $connection);
mysql_set_charset('latin1', $connection);
$result = mysql_query('SELECT notes FROM categories WHERE id = 16', $connection);
$latin1Str = mysql_result($result, 0);
$latin1Str = substr($latin1Str, strpos($latin1Str, 'Georgia'), 16);
// Try to convert it to UTF-8
$utf8Str = iconv('ISO-8859-1', 'UTF-8', $latin1Str);
// Output both
var_dump($latin1Str);
var_dump($utf8Str);
当我在firefox的源代码视图中运行它时,确保firefox的编码设置设置为“western(iso-8859-1)”,我会得到:

到目前为止,一切都很好。第一个输出包含那个奇怪的引用,我可以正确地看到它,因为它在ISO-8859-1中,而火狐也是。
在我将firefox的编码设置更改为“utf-8”之后,如下所示:

报价单到哪里去了?不是
iconv()
应该把它转换成UTF-8吗?
在尝试使用PHP将ISO-8859-1编码的数据库内容转换为UTF-8时,博主遇到了困扰。通过连接数据库并检索包含特殊字符的字符串,然后使用iconv函数进行转换,博主发现转换后的字符串在Firefox浏览器从ISO-8859-1切换到UTF-8编码显示时,特殊字符消失。问题在于转换过程似乎并未成功处理特殊字符。
872

被折叠的 条评论
为什么被折叠?



