今天就跟大家聊聊有關Jackson的JSON工具類如封裝 JsonUtils用法,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。
直接上代碼,都有注釋,一看就懂,完全滿足日常開發需求
import com.fasterxml.jackson.annotation.JsonInclude.Include;
import com.fasterxml.jackson.core.JsonProcessingException;
import com.fasterxml.jackson.core.type.TypeReference;
import com.fasterxml.jackson.databind.DeserializationFeature;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.SerializationFeature;
import com.fasterxml.jackson.datatype.jsr310.JavaTimeModule;
import java.io.IOException;
import java.text.SimpleDateFormat;
import lombok.extern.slf4j.Slf4j;
/**
* 基于Jackson的JSON轉換工具類
*
* @author ye17186
* @version 2018/6/29 12:06
*/
@Slf4j
public class JsonUtils {
private static ObjectMapper om = new ObjectMapper();
static {
// 對象的所有字段全部列入,還是其他的選項,可以忽略null等
om.setSerializationInclusion(Include.ALWAYS);
// 設置Date類型的序列化及反序列化格式
om.setDateFormat(new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"));
// 忽略空Bean轉json的錯誤
om.configure(SerializationFeature.FAIL_ON_EMPTY_BEANS, false);
// 忽略未知屬性,防止json字符串中存在,java對象中不存在對應屬性的情況出現錯誤
om.configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES, false);
// 注冊一個時間序列化及反序列化的處理模塊,用于解決jdk8中localDateTime等的序列化問題
om.registerModule(new JavaTimeModule());
}
/**
* 對象 => json字符串
*
* @param obj 源對象
*/
public static <T> String toJson(T obj) {
String json = null;
if (obj != null) {
try {
json = om.writeValueAsString(obj);
} catch (JsonProcessingException e) {
log.warn(e.getMessage(), e);
throw new IllegalArgumentException(e.getMessage());
}
}
return json;
}
/**
* json字符串 => 對象
*
* @param json 源json串
* @param clazz 對象類
* @param <T> 泛型
*/
public static <T> T parse(String json, Class<T> clazz) {
return parse(json, clazz, null);
}
/**
* json字符串 => 對象
*
* @param json 源json串
* @param type 對象類型
* @param <T> 泛型
*/
public static <T> T parse(String json, TypeReference type) {
return parse(json, null, type);
}
/**
* json => 對象處理方法
* <br>
* 參數clazz和type必須一個為null,另一個不為null
* <br>
* 此方法不對外暴露,訪問權限為private
*
* @param json 源json串
* @param clazz 對象類
* @param type 對象類型
* @param <T> 泛型
*/
private static <T> T parse(String json, Class<T> clazz, TypeReference type) {
T obj = null;
if (!StringUtils.isEmpty(json)) {
try {
if (clazz != null) {
obj = om.readValue(json, clazz);
} else {
obj = om.readValue(json, type);
}
} catch (IOException e) {
log.warn(e.getMessage(), e);
throw new IllegalArgumentException(e.getMessage());
}
}
return obj;
}
}如何使用就更簡單了
public static void main(String[] args) {
TestModel model1 = new TestModel();
model1.setId("A");
model1.setDate1(new Date());
model1.setDate2(LocalDate.now());
model1.setDate3(LocalDateTime.now());
model1.setTime(LocalTime.now());
TestModel2<TestModel> model2 = new TestModel2<>();
model2.setId("PA");
model2.setSub(model1);
String json1 = JsonUtils.toJson(model1);
String json2 = JsonUtils.toJson(model2);
System.out.println(json1);
System.out.println(json2);
// 簡單對象可以用這個
TestModel obj1 = JsonUtils.parse(json1, TestModel.class);
TestModel2<TestModel> obj2 = JsonUtils.parse(json2, TestModel2.class);
// 需要準確泛型的復雜對象可以用這個,這種方式與上面有細微差別,讀者可以自行debug研究
TestModel2<TestModel> obj3 = JsonUtils
.parse(json2, new TypeReference<TestModel2<TestModel>>() {
});
System.out.println(obj1);
System.out.println(obj2);
System.out.println(obj3);
}程序輸出:

看完上述內容,你們對Jackson的JSON工具類如封裝 JsonUtils用法有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。