繁体   English   中英

为什么从数据库加载的 JSON 上的 PHP json_decode 不起作用?

[英]Why is PHP json_decode on JSON loaded from a database not working?

我正在使用json_encode(["something" => ["hello", "world"]])对 JSON 进行编码,然后将其保存到数据库中。

数据库存储 JSON,如下所示:

{"something":["hello","world"]}

当使用json_decode($data)从数据库中解码这些数据,然后 print_ring 打印结果如下:

{"something":["hello","world"]}

在尝试解码之前,我已经对数据库中的数据进行了以下尝试:

$data = urldecode($data);

$data = htmlspecialchars_decode($data);

$data = str_replace(""", "\"", $data);

$data = str_replace(""", "\\\"", $data);

$data = str_replace("\u0022","\\\\\"", $data);

但没有成功。 我究竟做错了什么? 我该如何解决?

所以,如果我正确理解了这个问题,你可以对数据进行编码(变成一个字符串)并存储它。 然后您检索字符串并对其进行解码。 它又变成了一个字符串?

  • 当您说“回声”时,您实际上是在使用回声吗? (因为如果你期望它变成 object 或数组,你实际上不应该使用 echo)
  • 您是否在数据库中将其存储为 UTF-8 ? - json_decode 接受的 JSON 必须是 UTF8

最有可能的是,您应该在插入和检索时查看字符串 escaping。 https://www.php.net/manual/en/pdo.quote.php

(总是准备语句: https://www.php.net/manual/en/pdo.prepare.php

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM