看源码它能够做用于字段和方法上。json
1.做用Fieldspa
@JSONField做用在Field时,其name不只定义了输入key的名称,同时也定义了输出的名称。code
可是我在使用中,发现并不如上所说:orm
例如:对象
@JSONField(name="project_id") private Long ProjectID
发现bean 转json的时候并是"project_id":xxx的形式,json转bean的时候也不会把"project_id":xx的内容设置到ProjectID的里面。blog
fastjson的版本是1.1.15get
2.做用在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") public void setProjectID(Long projectID) { ProjectID = projectID; }
3.@JSONField其它用法it
查看@JSONField注解的源码,除了name可用以外,还有format,serialize,deserialize,serialzeFeatures,parseFeatures可用ast
@JSONField(serialize=false) private Long ProjectID
就是在序列化的时候就不包含这个字段了。deserialize与之相反。可是有一点须要注意,我看其它地方说,当字段为final的时候注解放在字段上是不起做用的,这时候应该放在get或set方法上。
还有一种使用方法:在对象对应字段前面加上transient,表示该字段不用序列化,即在生成json的时候就不会包含该字段了。
private transient String name;
{"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}