您好,登錄后才能下訂單哦!
今天就跟大家聊聊有關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進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。