从上述例子可以看到fastjson会正确取出userDetail下的address数据,实际上所有的json开源项目都支持这种关联取出。但有时候我们并不需要userDetail下的数据,如果自动加载一堆无关的数据,甚至产生死循环,怎么解决呢?
第一种办法:
前面已经讲过,加上transient关键字,如给User PO的UserDetail定义改成
private transient UserDetail userDeatil;
第二种办法:
第一种办法是通用的办法,使用其他json开源项目,也可以达到效果,在FastJson下还可以使用@JSONField(serialize=false)
@JSONField(serialize=false)
private transient UserDetail userDeatil;
当然JSONField还有其他参数可以指定,以实现成员定制序列化,一般情况下,如果我们确定成员可以为非序列化,首先建议使用transient。但有时候指定了transient会引起其他问题,假如User对象下有长字段remark,如果给remark指定了transient,那么在比如使用Mongo数据库情况下,会导致页面提交的remark数据不能被保存到数据库,其他没有加transient关键字的字段能正常保存。这时就可以使用@JSONField来解决问题。
第三种办法:
假如有更进一步的优化,比如场景A的时候需要系列化remark,而在场景B的时候又不需要系列化,那就使用fastjson定制过滤器,fastjson可以按name、property、value三种过滤,以property例,重写获取List<user>这段伪码:
….
List<User> ls= userService.getUserList();
PropertyFilter filter = new PropertyFilter() {
public boolean apply(Object source, String name, Object value) {
".equals(name)) {
return true;
}
return false;
}
};
SerializeWriter sw = new SerializeWriter();
JSONSerializer serializer = new JSONSerializer(sw);
serializer.getPropertyFilters().add(filter);
serializer.write(ls);
PrintWriter out = null;
try {
out = getResponse().getWriter();
out.write(sw.toString());
out.flush();
} catch (IOException e) {
e.printStackTrace();
} finally {
out.close();
}
…
这样在碰到场景B时就使用第三种办法把remark这个成员给过滤掉,在场景A的情况下不加过滤器即可。