java解析复杂json

我个人验证了两个方法

一.基于org.json

1.jar包依赖

复制代码
<!-- https://mvnrepository.com/artifact/org.json/json -->
<dependency>
	<groupId>org.json</groupId>
	<artifactId>json</artifactId>
	<version>20240303</version>
</dependency>

2.test json,精简后的测试json

复制代码
level1Array: [{
	"couponId": "DBD6E1A48CC699C942618BE41CA231DA",
	"title": "11.9元麦辣鸡腿堡",
	"couponCode": [{
		"couponCodeEndTime": "2024-12-23 23:59:59",
		"couponCardType": 0
	}],
	"remainQuantity": 29455158,
	"promotionId": "111799015",
	"receiveQuantity": 1
}, {
	"couponId": "D8989417A8CBE902E55D96CED8B81C54",
	"title": "姜姜暖奶铁买一送一",
	"couponCode": [{
		"couponCodeEndTime": "2024-12-27 23:59:59",
		"couponCardType": 0
	}],
	"remainQuantity": 1720778,
	"promotionId": "111756005",
	"receiveQuantity": 1
}]

3.解析源码,代码都是验证过的

复制代码
/**jackson解析*/
    void paserJsonByJackson(){

        try {
            String jsonContent = new String(Files.readAllBytes(Paths.get("D://1/coujsontest.json")));

            ObjectMapper objectMapper = new ObjectMapper();
            //第一层
            JsonNode rootJsonNode = objectMapper.readTree(jsonContent);

            String msgId = rootJsonNode.get("msgId").asText();
            String traceId = rootJsonNode.get("traceId").asText();
            String from = rootJsonNode.get("from").asText();

            logger.info("msgId: " + msgId);
            logger.info("traceId: " + traceId);
            logger.info("from: " + from);

            //第一层的body node
            JsonNode bodyNode = rootJsonNode.get("body");
            //第二层的body attribute
            String customerId = bodyNode.get("customerId").asText();
            int receiveType = bodyNode.get("receiveType").asInt();
            String tradeNo = bodyNode.get("tradeNo").asText();

            logger.info("customerId: " + customerId);
            logger.info("receiveType: " + receiveType);
            logger.info("tradeNo: " + tradeNo);
            //第二层的body 的 coupons node
            JsonNode couponsNode = bodyNode.get("coupons");
            for(int i = 0;i<couponsNode.size();i++){
                //第三层的couponsNode 的 coupon node
                JsonNode couponNode = couponsNode.get(i);
                //第三层的couponNode 的 attribute
                String couponId = couponNode.get("couponId").asText();
                String couponTitle = couponNode.get("title").asText();
                String couponPromotionId = couponNode.get("promotionId").asText();
                int couponReceiveQuantity = couponNode.get("receiveQuantity").asInt();
                int couponRemainQuantity = couponNode.get("remainQuantity").asInt();

                logger.info("couponId: " + couponId);
                logger.info("couponTitle: " + couponTitle);
                logger.info("couponPromotionId: " + couponPromotionId);
                logger.info("couponReceiveQuantity: " + couponReceiveQuantity);
                logger.info("couponRemainQuantity: " + couponRemainQuantity);
                //第三层的couponNode 的 couponCodeNode
                JsonNode couponCodeNode = couponNode.get("couponCode");
                for(int j = 0;j<couponCodeNode.size();j++){
                    //第四层的couponCodeNode 的 couponCode node
                    JsonNode couponCode = couponCodeNode.get(j);
                    //第四层的couponCode 的 couponCode node
                    int isAvailable = couponCode.get("isAvailable").asInt();
                    int isDeleted = couponCode.get("isDeleted").asInt();
                    String createdUser = couponCode.get("createdUser").asText();
                    String updatedUser = couponCode.get("updatedUser").asText();
                    String updatedDate = couponCode.get("updatedDate").asText();
                    logger.info("isAvailable: " + isAvailable);
                    logger.info("isDeleted: " + isDeleted);
                    logger.info("createdUser: " + createdUser);
                    logger.info("updatedUser: " + updatedUser);
                    logger.info("updatedDate: " + updatedDate);
                }

            }

        } catch (Exception e) {
            e.printStackTrace();
        }
    }

二、基于jackson,spring内部解析json也是这个,最终生产上使用的这个;

1.jar依赖

复制代码
<!-- https://mvnrepository.com/artifact/com.fasterxml.jackson.core/jackson-core -->
<dependency>
	<groupId>com.fasterxml.jackson.core</groupId>
	<artifactId>jackson-core</artifactId>
	<version>2.18.2</version>
</dependency>

<!-- https://mvnrepository.com/artifact/com.fasterxml.jackson.core/jackson-databind -->
<dependency>
	<groupId>com.fasterxml.jackson.core</groupId>
	<artifactId>jackson-databind</artifactId>
	<version>2.18.2</version>
</dependency>

<!-- https://mvnrepository.com/artifact/com.fasterxml.jackson.core/jackson-annotations -->
<dependency>
	<groupId>com.fasterxml.jackson.core</groupId>
	<artifactId>jackson-annotations</artifactId>
	<version>2.18.2</version>
</dependency>

2.源码

复制代码
/**jackson解析*/
void paserJsonByJacksonTwo(){
    String json = "{\"name\": \"John\", \"age\": 30, \"address\": {\"street\": \"123 Main St\", \"city\": \"New York\"}}";

    try {
        ObjectMapper objectMapper = new ObjectMapper();
        JsonNode jsonNode = objectMapper.readTree(json);

        String name = jsonNode.get("name").asText();
        int age = jsonNode.get("age").asInt();
        JsonNode addressNode = jsonNode.get("address");
        String street = addressNode.get("street").asText();
        String city = addressNode.get("city").asText();

        logger.info("Name: " + name);
        logger.info("Age: " + age);
        logger.info("Street: " + street);
        logger.info("City: " + city);

    } catch (Exception e) {
        e.printStackTrace();
    }
}
相关推荐
晓晓莺歌1 分钟前
vue-router路由问题:可以通过$router.push()跳转,但刷新后又变成空白页面
前端·javascript·vue.js
Java菜鸟、4 分钟前
设计模式(代理设计模式)
java·开发语言·设计模式
前端大卫9 分钟前
vxe-table 在项目中的实践!【附源码】
前端·vue.js·前端工程化
Thanwind14 分钟前
JVM中的各类引用
java·jvm·jmm
前端Hardy17 分钟前
HTML&CSS:高颜值视差滚动3D卡片
前端·javascript·html
前端无涯20 分钟前
Vue---vue使用AOS(滚动动画)库
前端·javascript·vue.js
前端Hardy21 分钟前
HTML&CSS:超好看的数据卡片
前端·javascript·html
牧码岛22 分钟前
Web前端之隐藏元素方式的区别、Vue循环标签的时候在同一标签上隐藏元素的解决办法、hidden、display、visibility
前端·css·vue·html·web·web前端
面朝大海,春不暖,花不开26 分钟前
Spring Boot MVC自动配置与Web应用开发详解
前端·spring boot·mvc
知否技术26 分钟前
2025微信小程序开发实战教程(一)
前端·微信小程序