针对服务器端返回json中包含null的解决办法

在今天的开发过程中发现这样的一个问题:

因数据库字段类型包含null类型,然后服务器端查询到的数据封装成json格式后也包含null,然后导致客户端在解析的时候出现奔溃的情况。

本打算由客户端来解决这个问题,无非就是加个判断,但仔细一想,若返回的数据是一个多维数组且包含N多的字段,那么客户端在判断的时候需要逐一判断,如此一来CPU、内存什么的杠杠的就上去了

而后如此艰巨的任务自然而然就交由服务器端来解决。

你们都知道程序员大都很懒的,因此针对这个问题我也去搜索了,结果给出的答案不出我所料,基本上都是客户端来解决,可你他妈想啊,客户端就那么点内存还不够跑程序的,怎么能用来处理这种琐事呢。介于此,服务器端果断发挥大无畏的精神,既然搜索不到,那我们就自己写。

在对查询到的数据进行分析之后发现是一个多维数组,而且他娘的数组的长度还不确定,这尼玛还得用递归。

无限修改调试中…

经过不懈的努力终于有所成就了,我也就不卖关子了,直接上代码。

源码下载可前往该地址:

https://github.com/paopao7/null_handle

(请注意其中的&符号)

//数据null处理

/*

* 该方法递归判断传入的数组中的每一个值是否为null,若为Null,则转换为””

* $array:为要处理的数组或字符串

* $replace:为null要 替换成的字符串,默认为””,也可在调用该方法的时候,默认一个值例如 “kong”

* */

function null_handle(&$array,$replace=””){

if(is_array($array)){

foreach($array as $first_key=>&$first_item){

if(is_null($first_item)){

$array[$first_key] = &$replace;

}

if(is_array($first_item)){

null_handle($first_item,$replace);

}

}

}else{

$array = $replace;

}

return $array;

}

 

//调用方法

//第二个参数,可填可不填,填了则使用该参数,否则则使用默认””

null_handle($data,”kong”)


如果还有什么不明白的地方,欢迎加我QQ进行咨询,请注明技术咨询

本人QQ:980569038

也可以扫码本人微信:

若该文章对您有一定帮助,欢迎打赏

(点击图片可放大)

本人原创,转载请注明出处

http://www.itinfor.cn/archives/1278

 

Tagged , , ,

发表回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注