dongxia2068 2015-09-28 19:04
浏览 52

PHP echo / mysql不能正确处理特殊字符

I have a JSON file, accessed remotely from a third-party website. It contains strings with special characters such as these:

"name":"StatTrak\u2122 FAMAS | Pulse", and "name":"\u2605 Butterfly Knife | Case Hardened",

However, when I echo these values using the following PHP code:

$url = "https://www.example.com";

$json = file_get_contents($url);
$obj = json_decode($json);

$descriptions = $obj->rgDescriptions;
foreach ($descriptions as $key => $value) {
    echo htmlspecialchars($value->name);
    echo htmlspecialchars($value->name, ENT_QUOTES, 'UTF-8');
}

It prints these lines as:

StatTrak™ FAMAS | Pulse and ★ Butterfly Knife | Case Hardened

How can this be prevented? This also occurs when storing these values in a MySQL table.

I have also tried the following:

$enc = mb_detect_encoding($value->name, "UTF-8,ISO-8859-1");

echo (iconv($enc, "UTF-8", $value->name) . ",");

But the results are the same.

  • 写回答

1条回答 默认 最新

  • dongzhouhao4316 2015-09-28 19:17
    关注

    Set htmlspecialchars encoding to UTF-8.

    echo htmlspecialchars($value->name, ENT_QUOTES, 'UTF-8');
    
    评论

报告相同问题?

悬赏问题

  • ¥15 Python中的request,如何使用ssr节点,通过代理requests网页。本人在泰国,需要用大陆ip才能玩网页游戏,合法合规。
  • ¥100 为什么这个恒流源电路不能恒流?
  • ¥15 有偿求跨组件数据流路径图
  • ¥15 写一个方法checkPerson,入参实体类Person,出参布尔值
  • ¥15 我想咨询一下路面纹理三维点云数据处理的一些问题,上传的坐标文件里是怎么对无序点进行编号的,以及xy坐标在处理的时候是进行整体模型分片处理的吗
  • ¥15 CSAPPattacklab
  • ¥15 一直显示正在等待HID—ISP
  • ¥15 Python turtle 画图
  • ¥15 stm32开发clion时遇到的编译问题
  • ¥15 lna设计 源简并电感型共源放大器