0

所以我试图找到一种快速的方法来显示我的数据库中的所有结果,但我似乎无法弄清楚为什么我需要将utf8_encode()函数添加到我的所有文本中才能正确显示我的所有字符。

作为记录,我的数据库信息是法语和英语,所以我需要特殊字符,包括 à、ç、è、é、ê、î、ö、ô、ù(等等)。

我的表单页面有以下标签:

<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">

我的数据库、所有表格和所有字段都设置为utf8_general_ci.

当我想将数据库信息回显到页面上时,我使用以下查询:

public function read_information()
{
    global $db;
    $query = "SELECT * FROM table WHERE id='1' LIMIT 1";
    return $db->select($query);
}

并返回如下信息:

$info = $query->read_information();
<?php foreach ( $info as $dbinfo ) { ?>
    <pre><?php echo $dbinfo->column; ?></pre>
<?php } ?>

但是,如果我的字符串中有法语字符,我需要<pre><?php echo utf8_encode($info->column); ?></pre>,这是我真正想要避免的事情。

我已经阅读了 PHP.net 上关于 utf8_encode/utf8_decode、htmlentities/html_entity_decode 等的文档。但是,我似乎无法弄清楚为什么我需要为每个数据库结果添加一个特殊函数。

我也尝试过使用mysqli_query("SET NAMES 'utf8'", $mysqli);,但这并不能解决我的问题。我想我正在寻找的是某种快捷方式,我不必创建类似功能make_this_french_friendly()的东西。

4

4 回答 4

2

确保您正在使用的所有堆栈都从数据库、Web 服务器、页面元等设置为 UTF8,检查诸如

ini_set('default_charset', 'utf-8')

根据我的经验,应该输出简单的东西

于 2013-11-04T16:19:26.427 回答
0

正如@deceze 指出的那样,该线程使用$mysqli->set_charset('utf8');.

于 2013-11-04T16:29:59.493 回答
0

也许对您的文件使用没有 BOM 编码的 UTF-8?

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

... 在 PHP 中(您也可以使用“ini_set()”函数)和:

<meta charset="utf-8">

...在 HTML 中。

您还必须为您的数据库表设置正确的编码。

在 PHP 中错误地编码法语字符的“GET”方法可能重复

于 2013-11-04T16:35:05.047 回答
0

也许您的文本编码不是 UTF-8。

请看:UTF-8和不带BOM的UTF-8有什么区别?

也许它可以帮助你。

于 2013-11-04T16:59:24.240 回答