對象轉JSON字符串
/** * 將對象轉換為json格式的字符串 * * @param obj * @return String */ public static String obj2json(Object obj) { String json = ""; try { json = JSONObject.toJSONString(obj, SerializerFeature.WriteMapNullValue, SerializerFeature.WriteNullStringAsEmpty, SerializerFeature.DisableCircularReferenceDetect); } catch (Exception e) { e.printStackTrace(); return ""; } return json; }
附帶SerializerFeature說明
<dependency> <groupId>com.alibaba</groupId> <artifactId>fastjson</artifactId> <version>1.2.7</version> </dependency>
SerializerFeature屬性
| 名稱 |
含義 |
備注 |
| QuoteFieldNames |
輸出key時是否使用雙引號,默認為true |
|
| UseSingleQuotes |
使用單引號而不是雙引號,默認為false |
|
| WriteMapNullValue |
是否輸出值為null的字段,默認為false |
|
| WriteEnumUsingToString |
Enum輸出name()或者original,默認為false |
|
| UseISO8601DateFormat |
Date使用ISO8601格式輸出,默認為false |
|
| WriteNullListAsEmpty |
List字段如果為null,輸出為[],而非null |
|
| WriteNullStringAsEmpty |
字符類型字段如果為null,輸出為”“,而非null |
|
| WriteNullNumberAsZero |
數值字段如果為null,輸出為0,而非null |
|
| WriteNullBooleanAsFalse |
Boolean字段如果為null,輸出為false,而非null |
|
| SkipTransientField |
如果是true,類中的Get方法對應的Field是transient,序列化時將會被忽略。默認為true |
|
| SortField |
按字段名稱排序后輸出。默認為false |
|
| WriteTabAsSpecial |
把\t做轉義輸出,默認為false |
不推薦 |
| PrettyFormat |
結果是否格式化,默認為false |
|
| WriteClassName |
序列化時寫入類型信息,默認為false。反序列化是需用到 |
|
| DisableCircularReferenceDetect |
消除對同一對象循環引用的問題,默認為false |
|
| WriteSlashAsSpecial |
對斜杠’/’進行轉義 |
|
| BrowserCompatible |
將中文都會序列化為\uXXXX格式,字節數會多一些,但是能兼容IE 6,默認為false |
|
| WriteDateUseDateFormat |
全局修改日期格式,默認為false。JSON.DEFFAULT_DATE_FORMAT = “yyyy-MM-dd”;JSON.toJSONString(obj, SerializerFeature.WriteDateUseDateFormat); |
|
| DisableCheckSpecialChar |
一個對象的字符串屬性中如果有特殊字符如雙引號,將會在轉成json時帶有反斜杠轉移符。如果不需要轉義,可以使用這個屬性。默認為false |
|
| NotWriteRootClassName |
含義 |
|
| BeanToArray |
將對象轉為array輸出 |
|
| WriteNonStringKeyAsString |
含義 |
|
| NotWriteDefaultValue |
含義 |
|
| BrowserSecure |
含義 |
|
| IgnoreNonFieldGetter |
含義 |
|
| WriteEnumUsingName |
含義 |
