关于fastJSON的@JSONField

fastjson的@JSONField注解的一点问题

@JSONField

看源码它可以作用于字段和方法上。

引用网上说的,

  一、作用Field

       @JSONField作用在Field时,其name不仅定义了输入key的名称,同时也定义了输出的名称。

但是我在使用中,发现并不如上所说。

例如

@JSONField(name="project_id")
private Long ProjectID

发现bean 转json的时候并是"project_id":xxx的形式,json转bean的时候也不会把"project_id":xx的内容设置到ProjectID的里面。

fastjson的版本是1.1.15

  二、作用在setter和getter方法上 这种方式倒是在使用的过程当中符合期望。

/**bean 转json 时会把bean中的ProjectID转换为project_id */
    @JSONField(name="project_id")
    public Long getProjectID() {
        return ProjectID;
    }
/**json 转bean 时会把json中的project_id值赋值给projectID*/
    @JSONField(name="project_id")
    publicvoid setProjectID(Long projectID) {
        ProjectID = projectID;
    }
  三、@JSONField其它用法,
查看@JSONField注解的源码,除了name可用之外,还有format,serialize,deserialize,serialzeFeatures,parseFeatures可用,
  • format,貌似用在Date类型的字段来格式化时间格式比较有用。
  • serializedeserialize是布尔类型的,用法为
@JSONField(serialize=false) 
private Long ProjectID

    就是在序列化的时候就不包含这个字段了。deserialize与之相反。但是有一点需要注意,我看其它地方说,当字段为final的时候注解放在字段上是不起作用的,这时候应该放在get

或set方法上。

  • serialzeFeatures,我用到这个属性,fastjson默认的序列化规则是当你的字段的值为null的时候,它是不会给你序列化这个字段的,例如我有一个这样的需求,
{"fieldName":"project_id","operator":"is not","value":null}

一个对象序列化成这样,我的代码如下

    CriteriaVO criteriaVO = new CriteriaVO();
        criteriaVO.setFieldName("project_id");
        criteriaVO.setOperator("is not");
        criteriaVO.setValue(null);

默认的它只会序列化为如下结果

{"fieldName":"project_id","operator":"is not"}

当然fastjson还是允许你控制一下序列化的规则的。这就用到了SerializerFeature,这个一个枚举,里面有好几个值 ,具体的含义大家有兴趣的可以了解一下,

我只是用到了其中一个,

@JSONField(serialzeFeatures=SerializerFeature.WriteMapNullValue)
private String value;

这样当value的值为null的时候,依然会把它的值序列化出来。也就是下面的样子,这就是我想要的结果

{"fieldName":"project_id","operator":"is not","value":null}
 又遇到了另一个问题,当字段类型为int类型时,如
privateint start;
    privateint limit;

我如果不set值的时候,会序列化为下面这样

"limit":0,"start":0

默认为都是0了,而我的目标是如果不设置值的时候,它们不会出现。

我是简单地通过把他们的类型改为Integer了。应该有其它通过自定义序列化行为的方式来解决,暂不研究。



使用fastJSON转化JSON字符串   如果两个对象互相转化数据,如果属性名不统一,可是使用fastJSON的注解
如果使用fastJSON将对象people中的属性和值转换为JSON格式字符串,然后在使用fastJSON将这个字符串中的数据封装到student对象中,这个时候如果people对象和student对象中的属性不同名,
ls:people对象中的age 属性 和student对象中的sage属性,我们可以在people的age属性定义时添加注解@JSONfield(name="sage"),这样使用fastJSON将people对象转换为json字符串后,可以使用fastJSON将 字符串中的数据封装到student中(常用于webservice中使用其他平的接口时接口中相关属性名和自己平台中对象属性名不统一)

fastJSON提供的解决方案确实挺好用的,但是people对象以JSON格式向student对象传递数据,但是增强了people对象和student对象相互交换数据的耦合性(就说json格式的数据),但是影响不大,
假如people对象向teacher对象(有属性tage)交换数据已json格式,我们直接使用fastJSON转JSON格式字符串,得到一个字符串类型,然后将相应的sage调用字符串的replace("sage","tage")也可以实现

json格式的字符串使用fastJSON封装到对象中是,只对字符串中有的相关属性进行封装,没有的相关属性为null

你可能感兴趣的:(关于fastJSON的@JSONField)