thinkphp5遇到必须使用Db::raw方法而无法使用json格式传递Db对象
今天使用Thinkphp5做异步任务传递where参数时遇到一个问题:有一段如下代码:
$where['jst.supplier'] = ['exp', Db::raw('>0 or jst.is_supplier=1')];在使用swoole做异步任务时需要把where参数传递给异步任务处理,因为无法传递数组和对象只能传递字符串,所以需要把where数组转换成字符串;
以前一直是使用json_encode函数转换json字符串,结果在今天使用发现报错:
进一步追查发现,swoole_client传递的参数就有问题
原始参数是这样的:
结果使用json_encode生成之后是这样的:
网上找了很多办法都不太好,
最后尝试使用 serialize 函数对数组进行序列化,然后swoole服务端使用 unserialize 转换回数组,结果发现Db对象完全保留未发生丢失。
serialize方法虽然不json格式可读性高、占用字符少;但还是有可取之处。
来源:程序园用户自行投稿发布,如果侵权,请联系站长删除
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作! 懂技术并乐意极积无私分享的人越来越少。珍惜 前排留名,哈哈哈 热心回复! 谢谢楼主提供! 新版吗?好像是停更了吧。 感谢分享 前排留名,哈哈哈 前排留名,哈哈哈 过来提前占个楼 这个有用。 谢谢楼主提供! yyds。多谢分享 这个有用。 喜欢鼓捣这些软件,现在用得少,谢谢分享! 这个有用。 用心讨论,共获提升! 感谢分享,学习下。 yyds。多谢分享 谢谢分享,试用一下
页:
[1]
2