84669 人学习
152542 人学习
20005 人学习
5487 人学习
7821 人学习
359900 人学习
3350 人学习
180660 人学习
48569 人学习
18603 人学习
40936 人学习
1549 人学习
1183 人学习
32909 人学习
要用redis存数组,string类型的方式存储。使用PHP自带的json_encode和json_decode转换成json(失败)。PHP自带的序列化函数serialize和unserialize函数(成功)。有什么具体的差别吗?有大侠讲一下成功和失败的原理吗
拥有18年软件开发和IT教学经验。曾任多家上市公司技术总监、架构师、项目经理、高级软件工程师等职务。 网络人气名人讲师,...
看上去和 redis 关系不大吧。set 和 get 的 JSON 字符串应该是一致的吧。
你可以直接先把 json_encode 的字符串直接 json_decode 的结果打印出来看看。
json_encode
json_decode
我猜有可能是 json_decode($str, true) 少了参数写成 json_decode($str) 了,导致结果是一个对象而不是数组。
json_decode($str, true)
json_decode($str)
序列化和JSON本质上不是一回事, json是种数据格式
序列化是指把运行环境中的数据对象转化为流数据, 使之可以保存到文件或网络传输到别的地方使用.这个流数据经反序列化, 会还原为该语言下的数据对象每个语言都有自己的序列化方法
php 有比serialize更高效的方法, 便是igbinary_serialize() 和igbinary_unserialize()这两方法需要安装ibginary模块使用redis时配置
$reids->setOption(Redis::OPT_SERIALIZER,Redis::SERIALIZER_IGBINARY);
redis自动会进行序列化处理, 而不要每次都序列化后再set, 每次get后都要反序列化
关于序列化, 拿PHP来说
class Person{ private $_name = "default"; public function get_name(){ return $this->_name; } } $p = new Person; $sp = serialize($p); send2serverB($p);
你在A服务器序列化了一个对象实例, 在服务B中要使用该实例当然, 服务器B中也需要有类 Person的声明, 才能正常反序列化
function recieve_handle($sp){ $p = unserialize($p); // 反序列后, 能还原Person实例, 能使用实例的方法 // json只是种保存元数据的格式, 无法保存对象 $name = $p->get_name(); }
因为数据要保存或传输(所谓的I/O), 所以才有序列化一说json是种常用的数据流格式, 但它只能存元数据, 无法表达复杂的对象属性和方法
注意数据必须是utf8,gbk是encode不了的
就是json_encode不能序列话对象
看上去和 redis 关系不大吧。set 和 get 的 JSON 字符串应该是一致的吧。
你可以直接先把
json_encode
的字符串直接json_decode
的结果打印出来看看。我猜有可能是
json_decode($str, true)
少了参数写成json_decode($str)
了,导致结果是一个对象而不是数组。序列化和JSON本质上不是一回事, json是种数据格式
序列化是指把运行环境中的数据对象转化为流数据, 使之可以保存到文件或网络传输到别的地方使用.
这个流数据经反序列化, 会还原为该语言下的数据对象
每个语言都有自己的序列化方法
php 有比serialize更高效的方法, 便是
igbinary_serialize() 和
igbinary_unserialize()
这两方法需要安装ibginary模块
使用redis时配置
redis自动会进行序列化处理, 而不要每次都序列化后再set, 每次get后都要反序列化
关于序列化, 拿PHP来说
你在A服务器序列化了一个对象实例, 在服务B中要使用该实例
当然, 服务器B中也需要有类 Person的声明, 才能正常反序列化
因为数据要保存或传输(所谓的I/O), 所以才有序列化一说
json是种常用的数据流格式, 但它只能存元数据, 无法表达复杂的对象属性和方法
注意数据必须是utf8,
gbk是encode不了的
就是json_encode不能序列话对象