關于fastjson的@JSONField注解的一些問題(詳解)
@JSONField
看源碼它可以作用于字段和方法上。
引用網上說的,
一、作用Field
@JSONField作用在Field時,其name不僅定義了輸入key的名稱,同時也定義了輸出的名稱。
但是我在使用中,發(fā)現(xiàn)并不如上所說。
例如
@JSONField(name="project_id") private Long ProjectID
發(fā)現(xiàn)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默認的序列化規(guī)則是當你的字段的值為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還是允許你控制一下序列化的規(guī)則的。
這就用到了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了,而我的目標是如果不設置值的時候,它們不會出現(xiàn)。
我是簡單地通過把他們的類型改為Integer了。應該有其它通過自定義序列化行為的方式來解決,暫不研究。
以上這篇關于fastjson的@JSONField注解的一些問題(詳解)就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
SpringBoot通過ThreadLocal實現(xiàn)登錄攔截詳解流程
這篇文章主要介紹了SpringBoot(HandlerInterceptor)+ThreadLocal實現(xiàn)登錄攔截,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-05-05