所以我试图找到一种快速的方法来显示我的数据库中的所有结果,但我似乎无法弄清楚为什么我需要将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()
类型的函数。
答案 0 :(得分:2)
确保您使用的所有堆栈都从db,web server,page meta等设置为UTF8 检查像
这样的事情ini_set('default_charset', 'utf-8')
根据我的经验,应输出简单的东西
答案 1 :(得分:0)
正如@deceze所指出的,this thread使用$mysqli->set_charset('utf8');
提供了正确的见解。
答案 2 :(得分:0)
也许对您的文件使用没有BOM编码的UTF-8?
header('Content-type: text/html; charset=utf-8');
...在PHP中(您也可以使用“ini_set()”函数)和:
<meta charset="utf-8">
...在HTML中。
您还必须为数据库表设置正确的编码。
可能重复答案 3 :(得分:0)