java - spring返回json如何判斷會返回null還是empty?
問題描述
利用spring提供的@ResponseBody可以非常方便的返回的json對象。
但是有一個問題是,有時候無法判斷@ResponseBody會返回empty('')還是null,題主大致觀察了一下。好像對于java中的String不管是null還是'',最終通過json返回的都是'',而對于Object,都會返回null,而對于int型數(shù)據(jù)都會返回0。
請問上面的結(jié)論是否正確?
問題解答
回答1:這個跟你的pojo中的實例變量類型和使用的json庫有關(json庫可以設置對null如何處理)
回答2:1.返回POJO時可以將業(yè)務數(shù)據(jù)封裝,比如封裝成JSONResult類,里面有code,msg,data其中data是業(yè)務數(shù)據(jù)(也就是POJO實例),code是狀態(tài)碼,msg是說明,這樣當業(yè)務數(shù)據(jù)為空的時候,返回錯誤碼就好,這樣返回結(jié)果依然是json格式數(shù)據(jù),方便接口調(diào)用者處理。
2.直接返回JSON格式數(shù)據(jù),利用fastjson或者net.sf.json,直接返回JSONObject對象,將業(yè)務數(shù)據(jù)手動或者自動填入JSONObject對象中。
回答3:如果使用的Jackon庫的話可以再pojo上面注解@JsonSerialize(include = JsonSerialize.Inclusion.NON_NULL),這樣的話如果某個屬性值為null或者'',則序列化為json的時候不會包含key
相關文章:
1. 在mybatis使用mysql的ON DUPLICATE KEY UPDATE語法實現(xiàn)存在即更新應該使用哪個標簽?2. mysql - 表名稱前綴到底有啥用?3. Navicat for mysql 中以json格式儲存的數(shù)據(jù)存在大量反斜杠,如何去除?4. mysql - 怎么生成這個sql表?5. mysql儲存json錯誤6. 哭遼 求大佬解答 控制器的join方法怎么轉(zhuǎn)模型方法7. mysql - 數(shù)據(jù)庫表中,兩個表互為外鍵參考如何解決8. 編輯成功不顯示彈窗9. 怎么php怎么通過數(shù)組顯示sql查詢結(jié)果呢,查詢結(jié)果有多條,如圖。10. sql語句 - 如何在mysql中批量添加用戶?
