php无法读取utf8中的字符

标签 php mysql

我正在尝试执行以下简单操作:

<?php
 header("Content-Type: text/html;charset=UTF-8");

$con=mysqli_connect("localhost","dsdsds","test1234","dsdsds");
if (mysqli_connect_errno())
  {
  echo "Failed to connect to MySQL: " . mysqli_connect_error();
  }


$result = mysqli_query($con,"SELECT * FROM discounts");

while($row = mysqli_fetch_array($result))
  {
  echo $row['name'] . " " . $row['rate'];
  echo "<br>";
  }




?>

当我这样做时,我的输出显示为 ??????。在数据库表中,它正确显示为阿拉伯语。我究竟做错了什么?我也知道我应该添加代码以将 mysqli 设置为 utf8,当我这样做时,它会破坏脚本。

  if (!$mysqli->set_charset("utf8")) {
        printf("Error loading character set utf8: %s\n", $mysqli->error);
    } else {
        printf("Current character set: %s\n", $mysqli->character_set_name());
    }

期待您的支持

最佳答案

mysqli 有两种方法调用方法。面向过程和面向对象。您会在文档中看到这两种方法。

这是程序风格:

$con=mysqli_connect...
$result = mysqli_query...
$row = mysqli_fetch_array...

这是 OO 风格:

$mysqli = new mysqli("localhost"...
$mysqli->set_charset("utf8")
$result = $mysqli->query...
$row = $mysqli->fetch_array...

看起来您正在混合样式。将 $mysqli->set_charset 更改为 $mysqli_set_charset 并重试。

如果你喜欢我的意见,我更喜欢 OO 风格。

关于php无法读取utf8中的字符,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17862300/

相关文章:

php - 通知 : Array to string conversion on PDO database connection

没有与数据库紧密耦合并使用存储过程的 PHP 框架?

php - 自定义变量可以像 super 全局变量一样在每个页面上使用吗?

php - 在这种特殊情况下,如何从二维数组中检索数据?

php - 解决 Zend Date DST 错误

php - 在php和mysql中将数据插入数据库

php - 使用 SQL 查询获取所有匹配的行

python - Snow Leopard 上的 MySQL_Python

php - 如何测试数组指针是否在foreach循环中的第一个元素

javascript - 具有多个输入的自动完成搜索表单php mysql