PHP:使用 PDO 从 MySQL 数据库输出 utf8 时出现问题

2023-12-12

$dbo = new PDO("mysql:host=localhost;dbname=database", "databaseuser",
  "databasepassword", array(PDO::MYSQL_ATTR_INIT_COMMAND => "SET NAMES utf8"));
$dbo -> exec("set character_set_client='utf8'");
$dbo -> exec("set character_set_results='utf8'");
$dbo -> exec("set collation_connection='utf8_general_ci'");
$prepSnapRetrieve = $dbo->prepare(
  "SELECT * FROM znc_log WHERE `nick` LIKE :u AND `tstamp` BETWEEN :t1 AND :t2"
);
$prepSnapRetrieve->execute(array(':u' => str_replace("|osu","", $_GET['u']),
  ':t1' => $_GET['sns'], ':t2' => $_GET['sne']));
$snapshotListing = $prepSnapRetrieve->fetchAll();
echo("Snapshot of ".$_GET['u']. "'s chat on ".strftime("%e/%m/%g",$_GET['sne']));
echo("<br><br>");
foreach($snapshotListing as $chat) {
  echo "<i>" . " " . "[" . strftime("%H:%M:%S", $chat['tstamp']) . "]" .
   "</i> " . " ><u>" . $chat['channel'] . "</u>< " . "(<b>" .
   htmlspecialchars($chat['nick'])."</b>) ".htmlspecialchars($chat['message']);
  echo("<br>");
}

这段代码应该解析并输出以 UTF-8 存储的 IRC 数据 - 但在回显时,任何 unicode 内容都简单地显示为:

??????

我已经审查了几个问题并包含了几个据称的修复程序,但似乎没有任何效果。使用相同数据库的另一个脚本完美地呼应 UTF-8 内容,但它使用的是 PHP 的标准 MySQL 实现,而不是 PDO。我究竟做错了什么?


使用 UTF8 时存在多个故障点:

  • 确保表是utf8

    使用 SQL 命令Show Variables;检查表的 MySQL 字符设置。

  • 插入的数据是utf8

    您可以尝试类似的工具php我的管理员 or Adminer检查,如果
    数据插入正确。尝试通过该工具手动插入数据。 通过脚本插入时,不要使用基本字符串函数。总是使用他们的 mbstring 备择方案。放mb_internal_encoding( 'UTF-8' );让 PHP 在内部处理 UTF-8。

  • 获取的数据是utf8

    我只会使用$pdo->exec("SET NAMES utf8");并放弃其余的。因为SET NAMES x相当于SET character_set_client = x; SET character_set_results = x; SET character_set_connection = x;

  • 显示的数据是utf8

    如果这是在 html 页面中显示,请不要忘记设置元标记或标题
    "Content-Type: text/html; charset=utf-8".

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

PHP:使用 PDO 从 MySQL 数据库输出 utf8 时出现问题 的相关文章

随机推荐