看源碼它能夠做用於字段和方法上。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}