xml和json的判断格式是否相等
手动撸了个 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的判断格式是否相等的更多相关文章
- SpringBoot RestController 同时支持返回xml和json格式数据
@RestController 默认支持返回json格式数据,即使不做任何配置也能返回json数据 当接口需要支持xml或json两种格式数据时应该怎么做呢? 只要引入 Jackson xml的 ma ...
- 【.net 深呼吸】聊聊WCF服务返回XML或JSON格式数据
有时候,为了让数据可以“跨国经营”,尤其是HTTP Web有关的东东,会将数据内容以 XML 或 JSON 的格式返回,这样一来,不管客户端平台是四大文明古国,还是处于蒙昧时代的原始部落,都可以使用这 ...
- 使用CJSON库实现XML与JSON格式的相互转化
之前完成了一个两个平台对接的项目.由于这两个平台一个是使用json格式的数据,一个是使用xml格式的数据,要实现它们二者的对接就涉及到这两个数据格式的转化,在查阅相关资料的时候发现了这个CJSON库, ...
- Java 常见数据交换格式——xml、json、yaml
目录 数据交换格式介绍 XML 使用DOM方式解析 使用SAX方式解析 使用DOM4J方式解析 使用JDOM方式解析 JSON 使用JSONObject方式将数据转换为JSON格式 利用JSONObj ...
- C#对XML、JSON等格式的解析
C#对XML.JSON等格式的解析 一.C#对XML格式数据的解析 1.用XMLDocument来解析 XmlDocument xmlDocument = new XmlDocument(); xml ...
- 常用两种数据交换格式之XML和JSON的比较
目前,在web开发领域,主要的数据交换格式有XML和JSON,对于XML相信每一个web developer都不会感到陌生: 相比之下,JSON可能对于一些新步入开发领域的新手会感到有些陌生,也可能你 ...
- java XML转JSON格式
标签: XML转Json json 2014-05-20 20:55 6568人阅读 评论(6) 收藏 举报 分类: [J2SE基础](20) 代码如下所示,从这个例子中发现了代码库的重要性,如果 ...
- XML和JSON两种数据交换格式的比较
在web开发领域,主要的数据交换格式有XML和JSON,对于在 Ajax开发中,是选择XML还是JSON,一直存在着争议,个人还是比较倾向于JSON的.一般都输出Json不输出xml,原因就是因为 x ...
- xml转换为json格式时,如何将指定节点转换成数组 Json.NET
使用Json.NET转换xml成json时,如果xml只有单个节点,但json要求是数组形式[], JsonConvert.SerializeXmlNode 并不能自动识别 示例如下: RecordA ...
随机推荐
- python 一般处理
#!/usr/bin/env python# -*- coding:utf-8 -*-# Author:afei# QQ:97259460# date = 2019/8/29 s_code1=''s_ ...
- Golang 连接ActiveMQ
使用ActiveMQ库:github.com/go-stomp/stomp 示例代码 package main import ( "net" "fmt" &qu ...
- 工控随笔_25_西门子TIA 博图V14.SP1安装报错,授权错误
前面有一篇文章说过西门子的软件安装的时候太麻烦,很容易出现错误. 但是有些错误在安装的时候却没有关系,例如下面的错误. 如上图所示,安装已经到最后一步,总结前面的修改系统组态已经打勾(✔) ,而且提示 ...
- MyBatis踩坑之SQLProvider转义字符被删除问题
目录 踩坑背景 问题描述 原因追踪 解决方案 方法一 方法二 踩坑背景 项目架构:Spring Boot + MyBatis + MySQL. 使用MyBatis作为ORM框架,jdbc驱动使用的是m ...
- 【视频开发】ONVIF客户端搜索设备获取rtsp地址开发笔记(精华篇)
转载地址:http://blog.csdn.net/gubenpeiyuan/article/details/25618177 概要: 目前ONVIF协议家族设备已占据数字监控行业 ...
- thinkphp3.2.2公用函数
thinkphp3.2.2公用函数函数调用默认路径 home/Common/function.php
- C/C++ 每日一题
超长正整数的相加,题目链接:https://www.nowcoder.com/practice/5821836e0ec140c1aa29510fd05f45fc?tpId #include<al ...
- 基于DigitalOcean+LAMP+WordPress搭建个人网站
1. 注册DigitalOcean并新建主机 为了搭建个人网站首先需要一个可以在公网范围访问的主机,可以选用国内如阿里云.国外如DigitalOcean的各种云主机提供商,这里选用DigitalOce ...
- Delphi RSA签名与验签【支持SHA1WithRSA(RSA1)、SHA256WithRSA(RSA2)和MD5WithRSA签名与验签】
作者QQ:(648437169) 点击下载➨ RSA签名与验签 [delphi RSA签名与验签]支持3种方式签名与验签(SHA1WithRSA(RSA1).SHA256WithRSA(RSA2)和M ...
- python_操作linux上的mysql
在编写初期,遇见一个问题,发现怎么连接不上mysql,一直报错1045: 最后发现,只要下面的,连接写正确,不会出现这个问题, 只要你保证你的user.pwd是正确的, import pymysqld ...