所以我试图找到一种快速的方法来显示我的数据库中的所有结果,但我似乎无法弄清楚为什么我需要将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()
的东西。