@JSONField
看源碼它能夠做用於字段和方法上。json
引用網上說的,spa
1、做用Fieldcode
@JSONField做用在Field時,其name不只定義了輸入key的名稱,同時也定義了輸出的名稱。orm
可是我在使用中,發現並不如上所說。htm
例如對象
@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其它用法,
查看@JSONField註解的源碼,除了name可用以外,還有format,serialize,deserialize,serialzeFeatures,parseFeatures可用,
@JSONField(serialize=false) private Long ProjectID
就是在序列化的時候就不包含這個字段了。deserialize與之相反。可是有一點須要注意,我看其它地方說,當字段爲final的時候註解放在字段上是不起做用的,這時候應該放在get產品
或set方法上。
{"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類型時,如
private int start; private int limit;
我若是不set值的時候,會序列化爲下面這樣
"limit":0,"start":0
默認爲都是0了,而個人目標是若是不設置值的時候,它們不會出現。
我是簡單地經過把他們的類型改成Integer了。應該有其它經過自定義序列化行爲的方式來解決,暫不研究。
插播個廣告
老丈人家的粉皮兒,農產品,沒有亂七八糟的添加劑,歡迎惠顧