xjsonkits超輕量級 JSON / XML / YAML 解析門面 API
超輕量級 JSON / XML / YAML 的 正序列化 與 反序列化 的 門面框架,不依賴具體的 JSON 實現(xiàn),讓業(yè)務(wù)代碼與 Jackson、Gson、Fastjson 等徹底 解耦,讓你可以在需要的時候輕松切換項目底層實現(xiàn)!
安裝教程
Maven
使用 JsonKit API:
<dependency> <groupId>com.ejlchina</groupId> <artifactId>jsonkit-core</artifactId> <version>1.3.1</version> </dependency>
使用 Jackson 底層實現(xiàn):
<dependency> <groupId>com.ejlchina</groupId> <artifactId>jsonkit-jackson</artifactId> <version>1.3.1</version> </dependency>
使用 Gson 底層實現(xiàn):
<dependency> <groupId>com.ejlchina</groupId> <artifactId>jsonkit-gson</artifactId> <version>1.3.1</version> </dependency>
使用 Fastjson 底層實現(xiàn):
<dependency> <groupId>com.ejlchina</groupId> <artifactId>jsonkit-fastjson</artifactId> <version>1.3.1</version> </dependency>
以上依賴添加一個即可。
Gradle
implementation 'com.ejlchina:jsonkit-core:1.3.1'
使用 Jackson 底層實現(xiàn):
implementation 'com.ejlchina:jsonkit-jackson:1.3.1'
使用 Gson 底層實現(xiàn):
implementation 'com.ejlchina:jsonkit-gson:1.3.1'
使用 Fastjson 底層實現(xiàn):
implementation 'com.ejlchina:jsonkit-fastjson:1.3.1'
以上依賴添加一個即可。
使用說明
反序列化 toMapper
String json = "{\"name\":\"Jack\",\"age\":20}"; // 轉(zhuǎn)換為具有映射結(jié)構(gòu)的 Mapper 對象 Mapper mapper = JSONKit.toMapper(json); // 第一層的鍵集合大小 int size = mapper.size(); // 2 // 第一層的鍵值集合 Set<String> keys = mapper.keySet(); // ["name", "age"] // 按鍵名訪問 String 屬性 String name = mapper.getString("name"); // Jack // 按鍵名訪問 int 屬性 int age = mapper.getInt("age"); // 20 // 遍歷 Mapper 對象 mapper.forEach((key, data) -> { System.out.println(key); // 依次輸出 name 和 age System.out.println(data); // 依次輸出 Jack 和 20 }); System.out.println(mapper); // 輸出 {"name":"Jack","age":20}
反序列化 toArray
String json = "[20,{\"name\":\"Jack\"},\"JsonKit\"]"; // 轉(zhuǎn)換為具有數(shù)組結(jié)構(gòu)的 Array 對象 Array array = JSONKit.toArray(json); // 數(shù)組大小 int size = array.size(); // 3 // 按下標(biāo)獲取 int 數(shù)據(jù) int value = array.getInt(0); // 20 // 按下標(biāo)獲取 Mapper 數(shù)據(jù) Mapper mapper = array.getMapper(1); // {"name":"Jack"} // 按下標(biāo)獲取 String 數(shù)據(jù) String string = array.getString(2); // JsonKit // 遍歷 Array 對象 array.forEach(((index, data) -> { System.out.println(index); // 依次輸出 0、 1 和 2 System.out.println(data); // 依次輸出 20、 {"name":"Jack"} 和 JsonKit })); System.out.println(array); // 輸出 [20,{"name":"Jack"},"JsonKit"]
反序列化 toBean
String json = "{\"name\":\"Jack\",\"age\":20}"; // 根據(jù)類型 轉(zhuǎn)換為 Java Bean User user = JSONKit.toBean(User.class, json); String name = user.getName(); // Jack int name = user.getAge(); // 20
反序列化 toList
String json = "[{\"name\":\"Jack\",\"age\":20}, {\"name\":\"Tom\",\"age\":21}]"; // 根據(jù)類型 轉(zhuǎn)換為 Java List List<User> list = JSONKit.toList(User.class, json); int size = list.size(); // 2 User user1 = list.get(0); // {"name":"Jack","age":20} User user2 = list.get(1); // {"name":"Tom","age":21}
正序列化 toJson
User user = new User(); user.setName("Jack"); user.setAge(20); String json = JSONKit.toJson(user); // 轉(zhuǎn)換為 JSON 字符串 System.out.println(json); // 輸出 {"age":20,"name":"Jack"}
配置 JSONKit
如果已經(jīng)添加了如 jsonkit-jackson 的適配包,默認(rèn)不用任何配置即可正常使用。
但如果需要特殊配置,例如使用 Jackson 時,可在如下操作:
ObjectMapper objectMapper = new ObjectMapper(); // 對 ObjectMapper 進行配置... // 對 JSONKit 進行初始化 JSONKit.init(new JacksonDataConvertor(ObjectMapper));
使用其它擴展包也類似操作。
評論
圖片
表情
