@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") public void setProjectID(Long projectID) { ProjectID = projectID; }
三、@JSONField其它用法,
查看@JSONField注解的源碼,除了name可用之外,還有format,serialize,deserialize,serialzeFeatures,parseFeatures可用,
- format,貌似用在Date類型的字段來格式化時間格式比較有用。
- serialize和deserialize是布爾類型的,用法為
@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類型時,如
private int start; private int limit;
我如果不set值的時候,會序列化為下面這樣
"limit":0,"start":0
默認為都是0了,而我的目標是如果不設置值的時候,它們不會出現。
我是簡單地通過把他們的類型改為Integer了。應該有其它通過自定義序列化行為的方式來解決,暫不研究。
插播個廣告

老丈人家的粉皮兒,農產品,沒有亂七八糟的添加劑,歡迎惠顧