翼度科技»论坛 编程开发 PHP 查看内容

thinkphp5遇到必须使用Db::raw方法而无法使用json格式传递Db对象

4

主题

4

帖子

12

积分

新手上路

Rank: 1

积分
12
今天使用Thinkphp5做异步任务传递where参数时遇到一个问题:
有一段如下代码:
  1. $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格式可读性高、占用字符少;但还是有可取之处。
 

来源:https://www.cnblogs.com/cnxzb/p/18206238
免责声明:由于采集信息均来自互联网,如果侵犯了您的权益,请联系我们【E-Mail:cb@itdo.tech】 我们会及时删除侵权内容,谢谢合作!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x

举报 回复 使用道具