JSON数组转LIST集合(项目笔记)
需求介绍
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