JSON数组转LIST集合的两种方法

本文介绍了如何在Java中高效地将JSON数组转换为LIST,通过对比创建实体类与直接使用JSONArray,优化了解析过程并避免数据库操作。

需求介绍

	JSON字符串中包含多个集合,例如[{"a1":111,"a2":112,"a3":113},{"a1":"211","a2":"212","a3":"213"}........],现在后台获取到一个参数b,如果b=111,那么需要将{"a1":111,"a2":112,"a3":113}这组信息取出来后返回。

需求分析

	首先想到的是第一种方法,需要创建实体类,将数据信息取出来放进实体类中,然后再进行遍历取值。

创建实体类的转换方法

实体类(payTermInfo)创建略

public Map<String,String> getUnionPayTermInfo(String orgCode,Integer amount){

        if(StringUtils.isEmpty(orgCode)) return null;

        Parameter parameter =parameterService.findByNameWithCache(RedisKey.TermInfo);
        if(StringUtils.isEmpty(parameter.getParameterValue())){
            logger.info("终端信息未配置");
            return null;
        }

        Map<String, String> map = new HashMap<>();
        //判断用户是否可以参加活动
        try{
            List<payTermInfo> list = JSON.parseArray(parameter.getParameterValue(),payTermInfo.class);
            for(payTermInfo t : list){
                if(orgCode.equals(t.getProvince_code())){
                    if(t.getEnable().equals(0)){
                        if(amount >= Integer.valueOf(t.getMinAmount()) && amount < Integer.valueOf(t.getMaxAmount())){
                            logger.info("用户可以参加活动");
                            //经度 维度 终端入网认证编号 终端设备类型 终端序列号 加密随机因子 密文数据 应用程序版本号
                            map.put("longitude",t.getLongitude());
                            map.put("latitude",t.getLatitude());
                            map.put("networkLicense",t.getNetworkLicense());
                            map.put("deviceType",t.getTermDeviceType());
                            map.put("serialNum",t.getSerialNum());
                            map.put("encryptRandNum",t.getEncryptRandNum());
                            map.put("secretText",t.getSecretText());
                            map.put("appVersion",t.getAppVersion());
                            map.put("TermId",t.getTermId());
                        }
                    }
                }
            }
        }catch (Exception e){
            logger.info("Json转换失败");
            return null;
        }
        return map;
    }

但是这种方法也有缺点,第一,需要创建实体,并且需要在数据库中创建表,与实体字段对应。第二,JSON数据已经保存在缓存里了,再拿出来存放进数据库中再取出来,相当麻烦。所以第一次代码提交后被打了回来,那么第二种,利用JSONArray。

利用JSONArray遍历数组

public Map<String,String> getUnionPayTermInfo(String orgCode,Integer amount){

        if(StringUtils.isEmpty(orgCode)) return null;

        Parameter parameter =parameterService.findByNameWithCache(RedisKey.TermInfo);
        if(StringUtils.isEmpty(parameter.getParameterValue())){
            logger.info("终端信息未配置");
            return null;
        }

        Map<String, String> map = new HashMap<>();
        //判断用户是否可以参加活动
        try{
            //将json数据转换为json数组
            JSONArray jsonArray = JSONArray.parseArray(parameter.getParameterValue());
            //将jsonArray中的数组放进map中然后进行遍历,获取map的键值对信息
            List<Map> list =jsonArray.toJavaList(Map.class);
            for(Map map1 : list){
                if(map1.get("province_code").equals(orgCode)){
                    //enable为0是可以参加活动
                    if(map1.get("enable").equals(0)){
                        if(StringUtils.isEmpty(map1.get("MinAmount")) || StringUtils.isEmpty(map1.get("MaxAmount"))
                                || map1.get("MinAmount").equals("0") ||map1.get("MaxAmount").equals("0")){
                            //经度 维度 终端入网认证编号 终端设备类型 终端序列号 加密随机因子 密文数据 应用程序版本号
                            map.put("longitude", String.valueOf(map1.get("Longitude")));
                            map.put("latitude", String.valueOf(map1.get("Latitude")));
                            map.put("networkLicense", String.valueOf(map1.get("NetworkLicense")));
                            map.put("deviceType", String.valueOf(map1.get("TermDeviceType")));
                            map.put("serialNum", String.valueOf(map1.get("SerialNum")));
                            map.put("encryptRandNum", String.valueOf(map1.get("EncryptRandNum")));
                            map.put("secretText", String.valueOf(map1.get("SecretText")));
                            map.put("appVersion", String.valueOf(map1.get("AppVersion")));
                            map.put("TermId", String.valueOf(map1.get("TermId")));
                        } else if(amount >= (int) map1.get("MinAmount") && amount < (int)map1.get("MaxAmount")){
                            logger.info("用户可以参加活动");
                            //经度 维度 终端入网认证编号 终端设备类型 终端序列号 加密随机因子 密文数据 应用程序版本号
                            map.put("longitude", String.valueOf(map1.get("Longitude")));
                            map.put("latitude", String.valueOf(map1.get("Latitude")));
                            map.put("networkLicense", String.valueOf(map1.get("NetworkLicense")));
                            map.put("deviceType", String.valueOf(map1.get("TermDeviceType")));
                            map.put("serialNum", String.valueOf(map1.get("SerialNum")));
                            map.put("encryptRandNum", String.valueOf(map1.get("EncryptRandNum")));
                            map.put("secretText", String.valueOf(map1.get("SecretText")));
                            map.put("appVersion", String.valueOf(map1.get("AppVersion")));
                            map.put("TermId", String.valueOf(map1.get("TermId")));
                        }
                    }
                }
            }
        }catch (Exception e){
            logger.info("Json转换失败");
            return null;
        }
        return map;
    }

END

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值