我有一个symfony应用程序,它使用json_encode
和json_decode
来记录某些价格。
问题是json_decode
在一个文件中正常工作(我可以解码存储在我的PSQL数据库中的字符串),但是当我从其他文件json_decode
调用它时返回null,我检查文件编码(都是utf-8)表和数据库编码(也是utf-8)。所以我不知道问题出在哪里,也试过了utf8_encode()
......
任何帮助将不胜感激。 感谢。
这是有效的编码json(它是由php json_encode编码的数组)
{"1":{"1":{"fechaInicio":"30-05-2011","precios":{"1":{"precio":"20000","abreviatura":"CLP"}},"fechaRetiro":"31-05-2011"}},"2":{"2":{"fechaInicio":"30-05-2011","precios":{"1":{"precio":"20000","abreviatura":"CLP"}},"fechaRetiro":"31-05-2011"}}}
数组:
$preciosOfertor = Array ( [unidades] => Array ( [1] => Array ( [1] => Array ( [fechaInicio] => 30-05-2011 [precios] => Array ( [1] => Array ( [precio] => 20000 [abreviatura] => CLP ) ) [fechaRetiro] => 31-05-2011 ) ) [2] => Array ( [2] => Array ( [fechaInicio] => 30-05-2011 [precios] => Array ( [1] => Array ( [precio] => 20000 [abreviatura] => CLP ) ) [fechaRetiro] => 31-05-2011 ) ) ) )
要编码我使用:
$preciosOfertor = json_encode($preciosOfertor);
然后我打电话给
$precios = json_decode($databaseObject->getPreciosOfertor(),true);
当我在编码数组的文件中使用json_decode时,它会工作,但是当我在项目的其他文件中使用它时,我只使用var_dump()得到NULL。
按照建议安装了Services_JSON,但现在我得到一个空数组
带有Services_JSON的编码json就是这个:
{"unidades":{"1":{"1":{"fechaInicio":"30-05-2011","precios":{"1":{"precio":"20000","abreviatura":"CLP"}},"fechaRetiro":"31-05-2011"}}}}
但是当我调用$ json-> decode()时,我得到了Array()
答案 0 :(得分:2)
好的人,先谢谢大家的帮助。
我得到了解决方案,这完全归功于Zend Json库。
Symfony使用转义策略来防止XSS攻击,SQL注入攻击等。所以在我的情况下发生了什么,当我调用json_encode和json_decode时,它是在Doctrine生成的对象内部来表示我的对象(在这种情况下是一个预留) )因为它是对行数据(valoresOfertor)的本地调用,所以数据库中的数据没有被转义,因此方法运行正常。
但是,当我尝试对保留类之外的行的值进行编码和解码时,Symfony使用了它的转义策略,所以
"
成了
"
所以,尝试不同的JSON库,我使用了Zend,看到了显示的异常(语法错误:
at Zend_Json::decode('{"unidades":{"1":{"1":{"fechaInicio":"30-05-2011","precios":{"1":{"precio":"20000","abreviatura":"CLP"}},"fechaRetiro":"31-05-2011"}},"2":{"2":{"fechaInicio":"30-05-2011","precios":{"1":{"precio":"20000","abreviatura":"CLP"}},"fechaRetiro":"31-05-2011"}}}}')
in SF_ROOT_DIR/apps/saas/modules/editreserva/templates/habitacionesSuccess.php line 20 ...
然后我添加了以下行:
htmlspecialchars_decode($jsonVariable);
它有效。
如果他用symfony和json进行相同的实验,我希望能有所帮助。
答案 1 :(得分:0)
答案 2 :(得分:0)
从php.net:如果无法解码json或编码数据深于递归限制,则返回 NULL 。
因此,要么将e递归限制设置为低于数据深度(如果你说它在另一个页面上工作,则可能看起来似乎不是这样),或者json无法解码。
如果它在一个页面上工作而在另一个页面上不起作用,请检查文件编码
第一页可能被编码为utf-8(json的编码),但第二页可能是其他东西(如ascii)。也检查bom.Youw可能需要将页面编码为utf-8没有bom。
答案 3 :(得分:0)
据我所知,在以前版本的PHP中,json_encode()和json_encode()中存在一个或多个错误。您可以尝试将PHP更新到最新版本,也可以使用外部库对JSON进行编码和解码。有一些,但我认为PEAR JSON是最好的。
答案 4 :(得分:0)