手动撸了个 xml 和 json 格式匹配的代码。

    /**
* 判断数据的结构。遍历节点然后去对应的json那边查找是否存在这样的节点
*
* @param root 配置的xml所对应的对Element对象
* @param jsonObject 需要匹配的json字符串对应的json对象
* @return
*/
private boolean constructionCompared(Element root, JSONObject jsonObject) {
boolean f = true;
List<Element> elementList = root.elements();
for (Element element : elementList) {
String key = element.getName();
Object o = jsonObject.get(key);
if (o == null) {
return false;
}
if (o instanceof JSONObject) {
JSONObject t = (JSONObject) o;
f = f && constructionCompared(element, t);
if (f == false) {
return false;
}
} else if (o instanceof JSONArray) {
JSONArray t = (JSONArray) o;
if (t.size() == 0 && element.elements().size() > 0) {
return false;
}
f = f && constructionCompared(element, t.getJSONObject(0));
if (f == false) {
return false;
}
} else {
if (element.elements().size() > 0) {
return false;
}
}
}
return f;
}

测试数据:

json:

{
"unid":"F92933BF937B70976FB1DA330059F7B6",
"pass_device_unid":"41ACB22E9F0D131EFB97C382503E60F6",
"pass_area_unid":"0D77703E4AD042A6FA59807746331821",
"pass_bay_unid":"7AD94DCE176EB10602938BD164E156EC",
"pass_plate_no":"闽C3285W",
"pass_plate_type":"02",
"pass_datetime":"2019-05-26 08:33:10",
"pass_car_speed":"0.0",
"pass_car_length":"0.0",
"pass_plate_color":"H",
"pass_car_type":"K33",
"pass_pic_full_path":"35050001/F92933BF937B70976FB1DA330059F7B61",
"pass_pic_path2":"",
"pass_pic_path3":"",
"pass_car_status":"0",
"pass_car_color":"Z",
"pass_car_brand":"",
"pass_capture_no":"",
"pass_sec_code":"",
"pass_car_dw_index":"40424",
"pass_car_flag":"0",
"pass_create_time":"2019-05-26 08:34:53",
"pass_road_no":"1",
"pass_car_son_brand":"其他",
"pass_car_pic_site":"",
"pass_car_model":"",
"pass_road_to":"0",
"pass_identify_direction":"",
"illegal_code":"0",
"pass_deck":"0"
}

xml:

<root>
<unid>F92933BF937B70976FB1DA330059F7B6</unid>
<pass_device_unid>41ACB22E9F0D131EFB97C382503E60F6</pass_device_unid>
<pass_area_unid>0D77703E4AD042A6FA59807746331821</pass_area_unid>
<pass_bay_unid>7AD94DCE176EB10602938BD164E156EC</pass_bay_unid>
<pass_plate_no>闽C3285W</pass_plate_no>
<pass_plate_type>02</pass_plate_type>
<pass_datetime>2019-05-26 08:33:10</pass_datetime>
<pass_car_speed>0.0</pass_car_speed>
<pass_car_length>0.0</pass_car_length>
<pass_plate_color>H</pass_plate_color>
<pass_car_type>K33</pass_car_type>
<pass_pic_full_path>35050001/F92933BF937B70976FB1DA330059F7B61</pass_pic_full_path>
<pass_pic_path2></pass_pic_path2>
<pass_pic_path3></pass_pic_path3>
<pass_car_status>0</pass_car_status>
<pass_car_color>Z</pass_car_color>
<pass_car_brand></pass_car_brand>
<pass_capture_no></pass_capture_no>
<pass_sec_code></pass_sec_code>
<pass_car_dw_index>40424</pass_car_dw_index>
<pass_car_flag>0</pass_car_flag>
<pass_create_time>2019-05-26 08:34:53</pass_create_time>
<pass_road_no>1</pass_road_no>
<pass_car_son_brand>其他</pass_car_son_brand>
<pass_car_pic_site></pass_car_pic_site>
<pass_car_model></pass_car_model>
<pass_road_to>0</pass_road_to>
<pass_identify_direction></pass_identify_direction>
<illegal_code>0</illegal_code>
<pass_deck>0</pass_deck>
</root>

调用:

public void dataCheckTest(Map<String, Object> params) throws Exception {
String xml = String.valueOf(params.get("xml"));
String json = String.valueOf(params.get("json"));
JSONObject jsonObject = JSONObject.parseObject(json);
Document document = DocumentHelper.parseText(xml);
Element root = document.getRootElement();
boolean b = constructionCompared(root, jsonObject);
System.out.println(b);
}

xml和json的判断格式是否相等的更多相关文章

  1. SpringBoot RestController 同时支持返回xml和json格式数据

    @RestController 默认支持返回json格式数据,即使不做任何配置也能返回json数据 当接口需要支持xml或json两种格式数据时应该怎么做呢? 只要引入 Jackson xml的 ma ...

  2. 【.net 深呼吸】聊聊WCF服务返回XML或JSON格式数据

    有时候,为了让数据可以“跨国经营”,尤其是HTTP Web有关的东东,会将数据内容以 XML 或 JSON 的格式返回,这样一来,不管客户端平台是四大文明古国,还是处于蒙昧时代的原始部落,都可以使用这 ...

  3. 使用CJSON库实现XML与JSON格式的相互转化

    之前完成了一个两个平台对接的项目.由于这两个平台一个是使用json格式的数据,一个是使用xml格式的数据,要实现它们二者的对接就涉及到这两个数据格式的转化,在查阅相关资料的时候发现了这个CJSON库, ...

  4. Java 常见数据交换格式——xml、json、yaml

    目录 数据交换格式介绍 XML 使用DOM方式解析 使用SAX方式解析 使用DOM4J方式解析 使用JDOM方式解析 JSON 使用JSONObject方式将数据转换为JSON格式 利用JSONObj ...

  5. C#对XML、JSON等格式的解析

    C#对XML.JSON等格式的解析 一.C#对XML格式数据的解析 1.用XMLDocument来解析 XmlDocument xmlDocument = new XmlDocument(); xml ...

  6. 常用两种数据交换格式之XML和JSON的比较

    目前,在web开发领域,主要的数据交换格式有XML和JSON,对于XML相信每一个web developer都不会感到陌生: 相比之下,JSON可能对于一些新步入开发领域的新手会感到有些陌生,也可能你 ...

  7. java XML转JSON格式

    标签: XML转Json json 2014-05-20 20:55 6568人阅读 评论(6) 收藏 举报  分类: [J2SE基础](20)  代码如下所示,从这个例子中发现了代码库的重要性,如果 ...

  8. XML和JSON两种数据交换格式的比较

    在web开发领域,主要的数据交换格式有XML和JSON,对于在 Ajax开发中,是选择XML还是JSON,一直存在着争议,个人还是比较倾向于JSON的.一般都输出Json不输出xml,原因就是因为 x ...

  9. xml转换为json格式时,如何将指定节点转换成数组 Json.NET

    使用Json.NET转换xml成json时,如果xml只有单个节点,但json要求是数组形式[], JsonConvert.SerializeXmlNode 并不能自动识别 示例如下: RecordA ...

随机推荐

  1. rem js相关

    !function(n){ var e=n.document, t=e.documentElement, i=720, d=i/100, o="orientationchange" ...

  2. Centos7安装部署MongoDB教程

    安装方式: RPM包安装 安装步骤: 一.下载RPM包 下图是需要注意的事项.其一选择MongoDB的社区版本,默认是企业版本.其二,选中版本后,在下方会出现下载地址,直接复制下载即可  二.安装并查 ...

  3. Java分布式:分布式锁之Zookeeper

    Java分布式:分布式锁之Zookeeper 分布式锁系列教程重点分享锁实现原理 引入ZooKeeper ZooKeeper是什么呢? ZooKeeper 是一个开源的分布式协调服务,它可以在分布式系 ...

  4. npx vs npm

    npx vs npm npx 使用教程

  5. 如何科学的登陆GTA5

    GTA5一款不存在游戏 又是一年促销,在舍友的诱惑下,终于下决心买了GTA5的线上模式,但是到游玩的时候却遇到了很多麻烦. 我总结了有三个问题: 1.笔记本或者低配电脑运行起来很卡,掉帧. 2.网络延 ...

  6. 如何利用Docker构建基于DevOps的全自动CI

    来自用户的DevOps实践分享,分享从开发代码到生产环境部署的一条龙操作的实践及经验, 包含工具技术的选型及考量.私有代码库与私有镜像库的应用等. (一)容器服务的Rancher选型 1.为什么说是下 ...

  7. Git_从远程branch取回所有最新代码,暴力覆盖本地 && GIT基本结构

    假设你本地有一个xx分支对应着远端的xx分支,当前,你在本地的xx分支进行了修改(可以是执行了add, commit,但不要push),然后,现在想从远端的xx分支拿到最新的代码,可以用下图方法覆盖掉 ...

  8. intellij idea设置代码提示不区分大小写

    https://blog.csdn.net/csm0401/article/details/86306417

  9. 【基于onenet-edp的文件传输】1、调试上报数据点和端对端透传

    onenet-edp上报数据点和端对端透传 一.前言 edp是onenet用于tcp设备定制的一套协议,能够灵活地实现数据上报和透传: 二.准备工作 1.找到edp页面 进入工作台后,找到多协议接入, ...

  10. docker-compose up 启动容器服务超时错误:ERROR: An HTTP request took too long to complete. Retry with --verbose to obtain debug information.

    问题: 本人正在使用docker运行一个中型的项目,包含40多个微服务及相关的docker.由于docker-compose up 同时启动的服务过多,超过了请求HTTP限制的60s时间仍未全部成功启 ...