解决使用json-lib包实现xml转json时空值被转为空中括号的问题

项目数据库中出现许多值为中括号[]的数据,测试报了bug,经过排查是因为使用了json-lib 的jar包导致。json-lib在将xml字符串转换为json格式的过程中,会将空值转化了[],现在就简单的总结一下,两种xml转json包的异同。可能是因为此类问题比较初级,所以网上虽然有人提出此类问题,但是没有发现回答。为了方便像我一样的初级程序员能尽快的发现和解决问题,写了这篇博文。

网上能查到的xml转json的jar包大部分是net.sf.json-lib,这个包在json解析方面应用较多,但是缺点是需要的依赖包比较多。但是这里只讲他xml转json。

1、net.sf.json-lib 转json;

JSON json =xmlSerializer.read(xml);

这个方法出现的问题便是会将空值转化为[],使用 json.get(value).getclass 获取[]的类型可以发现:json-lib将空值识别为了jsonarray类型而不是string,而jsonarray的tostring方法被重写为[,,,,]

如果依然要使用这个方法,可以做如下修改,在使用getString()方法获取由xml转化的json对象值时,先判断类型是是否为string再获取。

json.get(value) instanceof String ? json.getString(value):"" 

2、org.json 转json :

org.json.JSONObject jsonObj = org.json.XML.toJSONObject(xml); 

不会生成[]值,但是会保留根标签(标准XML文档有且只有一个根标签,所谓的根标签就是一对<根标签></根标签>包含其他全部标签),而一般根标签对数据而言是没有意义的,所以你如果需要做处理的话

jsonObj.get("root"); 

下面是测试代码:

package com.pptv.ppvision.util; 

import org.json.XML;
import net.sf.json.JSONObject;
import net.sf.json.xml.XMLSerializer; 

public class Xml2JsonTest {
  private static String xml = "<root><user><name>weless</name><sex></sex></user></root>";
  public static void main(String[] args) {
    testOrgJSon();
    testXmlSerializer();
  } 

  public static void testOrgJSon(){
    org.json.JSONObject jsonObj = XML.toJSONObject(xml);
    System.out.println("org.json xml2json:"+jsonObj);
    org.json.JSONObject user = jsonObj.getJSONObject("root").getJSONObject("user");//org.json需去除根标签
    System.out.println("用户名:"+user.getString("name"));
    System.out.println("性别:"+user.getString("sex"));
  } 

  public static void testXmlSerializer(){
    XMLSerializer xmlSerializer = new XMLSerializer();
    JSONObject jsonObject = (JSONObject)xmlSerializer.read(xml);
    System.out.println("json-lib xml2json result: "+jsonObject);
    JSONObject user = jsonObject.getJSONObject("user");
    System.out.println("用户名:"+user.get("name"));
    System.out.println("性别:"+(user.get("sex") instanceof String ? user.getString("sex"):""));
  }
} 

这里为大家提供了两种方法

一种是使用getString()方法获取由xml转化的json对象值时,先判断类型是是否为string再获取

一种是org.json

大家可以根据自身需求选择使用哪种方法

(0)

相关推荐

  • Java的微信开发中使用XML格式和JSON格式数据的示例

    XML 微信XML消息model定义: package cn.wx.server; import org.dom4j.Document; import org.dom4j.DocumentException; import org.dom4j.DocumentHelper; import org.dom4j.Element; /** * @title cn.wx.serverXMLMsg.java * @todo TODO * @author lpe234 * @time 2014年5月21日下

  • json-lib将json格式的字符串,转化为java对象的实例

    json格式字符串中的日期是按照'yyyy-MM-dd HH:mm:ss'格式,如果按照常规的转换为对象,该日期则解析成当前系统时间 JSONObject json = JSONObject.fromObject(data); Dispatchplan dp = (Dispatchplan)JSONObject.toBean(json, Dispatchplan.class); 导致原因JSONObject可能无法识别日期格式,做了以下修改就解决 Dispatchplan dp = new Di

  • java将XML文档转换成json格式数据的示例

    本文介绍了java将XML文档转换成json格式数据的示例,分享给大家,具体如下: 功能 将xml文档转换成json格式数据 说明 依赖包: 1. jdom-2.0.2.jar : xml解析工具包; 2. fastjson-1.1.36.jar : 阿里巴巴研发的高性能json工具包 程序源代码 package com.xxx.open.pay.util; import com.alibaba.fastjson.JSONObject; import org.jdom2.Element; imp

  • 使用Ajax或Easyui等框架时的Json-lib的处理方案

    无论是使用ajax还是使用easyui等框架,后台向前台输出数据时都涉及到json处理的问题,这里介绍两种处理方法,第一种是手动配置json的处理方法,另一种使用json-lib的处理方案.普通手动配置方法比较笨拙,每次需要根据字段名逐个配置,因此也无法再其他对象上使用,降低了代码的重用性,使用json-lib工具可以实现自动处理,针对不同的对象又不同的处理措施,大大提高了处理效率和代码的重用性,以下分别根据案例介绍两种方法的过程: 方法一:普通方法,通过手动配置转型的过程,以easyui的请求

  • json-lib出现There is a cycle in the hierarchy解决办法

    解决办法 1.设置JSON-LIB让其过滤掉引起循环的字段. Java代码 复制代码 代码如下: JsonConfig config = new JsonConfig(); config.setIgnoreDefaultExcludes(false); config.setCycleDetectionStrategy(CycleDetectionStrategy.LENIENT); config.registerJsonValueProcessor(Date.class,new DateJson

  • 将Java对象序列化成JSON和XML格式的实例

    1.先定义一个Java对象Person: public class Person { String name; int age; int number; public String getName() { return name; } public void setName(String name) { this.name = name; } public int getAge() { return age; } public void setAge(int age) { this.age =

  • Java 使用json-lib处理JSON详解及实例代码

    Java 使用json-lib处理JSON详解 [项目环境] <dependency> <groupId>net.sf.json-lib</groupId> <artifactId>json-lib</artifactId> <version>2.4</version> <classifier>jdk15</classifier> </dependency> 1. JSON 数组对象转化

  • 解决使用json-lib包实现xml转json时空值被转为空中括号的问题

    项目数据库中出现许多值为中括号[]的数据,测试报了bug,经过排查是因为使用了json-lib 的jar包导致.json-lib在将xml字符串转换为json格式的过程中,会将空值转化了[],现在就简单的总结一下,两种xml转json包的异同.可能是因为此类问题比较初级,所以网上虽然有人提出此类问题,但是没有发现回答.为了方便像我一样的初级程序员能尽快的发现和解决问题,写了这篇博文. 网上能查到的xml转json的jar包大部分是net.sf.json-lib,这个包在json解析方面应用较多,

  • C# XML与Json之间相互转换实例详解

    对于这转换其实很简单,其中最重要的就是先要引用类库.可以到官网进行下载引用http://json.codeplex.com. XML转换为Json字符串 复制代码 代码如下: string xml = @"<?xml version=""1.0"" standalone=""no""?>                             <root>                   

  • Python中xml和json格式相互转换操作示例

    本文实例讲述了Python中xml和json格式相互转换操作.分享给大家供大家参考,具体如下: Python中xml和json格式是可以互转的,就像json格式转Python字典对象那样. xml格式和json格式互转用到的xmltodict库 安装xmltodict库 C:\Users\Administrator>pip3 install xmltodict Collecting xmltodict   Downloading xmltodict-0.11.0-py2.py3-none-any

  • 解决pycharm导入numpy包的和使用时报错:RuntimeError: The current Numpy installation (‘D:\\python3.6\\lib\\site-packa的问题

    标题用pycharm导入numpy包的和使用时报错:RuntimeError: The current Numpy installation ('D:\python3.6\lib\site-packages\numpy\init.py 1.file→settings→project interpreter→+(建议用pychon3.6版本,我之前用3.8版本安装不上numpy), 2.搜索numpy,注意把下面对号点上 3.现在简单用numpy还是会报错:RuntimeError: The cu

  • 10分钟掌握XML、JSON及其解析

    引言 NOKIA 有句著名的广告语:"科技以人为本".任何技术都是为了满足人的生产生活需要而产生的.具体到小小的一个手机,里面蕴含的技术也是浩如烟海,是几千年来人类科技的结晶,单个人穷其一生也未必能掌握其一角.不过个人一直认为基本的技术和思想是放之四海而皆准的,许多技术未必需要我们从头到尾再研究一遍,我们要做的就是站在巨人的肩膀上,利用其成果来为人们的需求服务. 随着移动互联网时代的大潮,越来越多的App不光是需要和网络服务器进行数据传输和交互,也需要和其他 App 进行数据传递.承担

  • 详解XML,Object,Json转换与Xstream的使用

    详解XML,Object,Json转换与Xstream的使用 1.Xstream的特点: 这里直接引用Xstream官方的叙述: 灵活易用:在更高的层次上提供了简单.灵活.易用的统一接口,用户无需了解项目的底层细节 无需映射:大多数对象都可以在无需映射的情况下进行序列化与反序列化的操作 高速稳定:设计时力求达到的最重要的指标是解析速度快.占用内存少,以使之能够适用于大的对象处理或是对信息吞吐量要求高的系统 清晰易懂:项目采用reflection机制得到无冗余信息的XML文件.所生成 的XML文件

  • java实现Xml与json之间的相互转换操作示例

    本文实例讲述了java实现Xml与json之间的相互转换操作.分享给大家供大家参考,具体如下: 旁白: 最近关于xml与json之间的转换都搞蒙了,这里写一个demo,以后备用. 正题: project格式是: jar包是一个一个检出来的,还算干净了. 代码: 工具类: package exercise.xml; import net.sf.json.JSON; import net.sf.json.JSONSerializer; import net.sf.json.xml.XMLSerial

  • 解决python 虚拟环境删除包无法加载的问题

    项目开发一直在docker的虚拟环境上,遇到了一个问题,就是把虚拟环境的包删掉(rm -rf xxx)之后,再重新拷贝一个(跟原来包一模一样的文件夹)进去发现pycharm再也找不到这个包了,后来在同事的帮助下一步步的解决了这个问题: 解决流程: 1.定位问题 在虚拟环境下引入这个包: #进入虚拟环境 source bin/activate #1.进入python #2.引入报错的包 (xenwebsite-env)[root@aeb02c10de04 xenwebsite-env]# pyth

  • 解决idea使用maven编译正常但是运行项目时却提示很多jar包找不到的问题

    如题,编译和打包都是正常的,pom文件中依赖存在并且没有报错.找到相应包的引用位置,也能正常访问包中的内容.而且提示的一般都是基础的jar包找不到,比如单元测试用到的jar包等... 情形一: 其他同事提交代码时把idea中的 .iml 文件也一起提交了,该文件中配置的jdk lib 路径与自己电脑中的该路径不一致. 解决方法很简单,执行一下 maven update 即可,也可以手动修改 .iml 文件中的该路径. 情形二: 排除情形一出现的原因,或使用情形一中的方法解决无效时,可以使用以下命

  • Android 解决游戏发行切包资源索引冲突的问题

    背景 游戏发行切包过程中,经常碰到渠道.研发.发行方,三方资源在合并过程中,资源ID冲突导致程序异常的问题,此类问题通过getIdentifier方式规避或者修改冲突资源ID的方式可以处理,但成本较高,本文旨在提出一种在切包过程中自动化处理资源冲突的解决方案 1.public.xml介绍 1.public.xml这个文件是哪来的? 该文件是apktool在反编译apk时,根据apk包中的resources.arsc文件生成. 没看过resource.arsc? (自己拖个apk到IDE看吧) 2

随机推荐