0

一劳永逸地,我想清楚如何在我的应用程序中处理 ü 等。我知道使用 UTF-8 是存储/表示这些奇怪字符的最佳方式。

所以我在我的 HTML 中声明了一个元字符集:

<meta charset="utf-8">

将内容存储在我的数据库中,它还需要正确的设置,所以我将排序规则设置为utf8_general_ci

统一码

据我了解,没有其他地方可以定义字符集。但问题是什么?

如果我进入 phpMyAdmin 并在内容字段中添加 jülich,然后通过 mysql 查询和 PHP 从数据库中减去内容。ü 正确显示。但是,如果我在 Textarea 中查看它,它会显示一个黑色菱形图形和一个白色 ? 在里面。

如果我在我的应用程序的文本区域中输入文本并提交,它会在文本区域中显示正确。但在网站上显示 ü

这些是 phpMyAdmin 启动屏幕中的字符集设置: phpMyadmin

作为对大安问题的回答:

特点%:

phpMyadmin

character_set_client = utf8
character_set_connection = utf8
character_set_database = utf8
character_set_filesystem = binary
character_set_results = utf8
character_set_server = latin1
character_set_system = utf8
character_sets_dir = /usr/share/mysql/charsets/

整理%

phpMyadmin

collation_connection = utf8_general_ci
collation_database = utf8_general_ci
collation_server = latin1_swedish_ci

我该如何解决这个问题?

到目前为止我做过的事情:

添加:header('Content-type: text/html; charset=utf-8');

添加:$this->db->setAttribute(PDO::MYSQL_ATTR_INIT_COMMAND, "SET NAMES 'utf8'");

添加:<meta http-equiv="content-type" content="text/html; charset=utf-8" />

添加:$this->db = new PDO($dsn, $username, $password, array(PDO::MYSQL_ATTR_INIT_COMMAND => "SET NAMES utf8"));

解决方案

以上所有内容都像魅力一样工作。但是如果你使用一个函数来替换某些特殊的例程并通过utf8_decode()它返回被替换的字符串显然不会显示 ü ;(

4

3 回答 3

1

您应该真正阅读MySQL 特定的 PDO 文档,因为它明确指出 PDO::MYSQL_ATTR_INIT_COMMAND 常量只能在构造新数据库句柄时在 driver_options 数组中使用。

因此,您应该在创建 PDO 句柄时指定 MYSQL_ATTR_INIT_COMMAND 而不是使用 setAttribute,如下所示:

$this->db = new PDO($dsn, $username, $password,
                    数组(PDO::MYSQL_ATTR_INIT_COMMAND => "SET NAMES utf8"));
于 2012-04-16T22:09:41.907 回答
0

我的猜测是这可能是浏览器方面的事情。还有几件事要检查:

  1. 您的 Web 服务器为Content-Type标头发送什么?它使用charset=utf-8吗?
  2. DOCTYPE您的 HTML 页面中是否指定了不同的字符集?
于 2012-04-16T21:06:09.587 回答
0

确保 phpMyAdmin本身已正确配置为使用 UTF8。听起来好像不是。

于 2012-04-16T21:34:56.297 回答