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

栏目: 编程语言 · 发布时间: 6年前

内容简介:网上能查到的xml转json的jar包大部分是net.sf.json-lib,但是JSON json =xmlSerializer.read(xml); 方法会出现将空值转化为[]的问题,下面为大家提供两种解决方法

项目数据库中出现许多值为中括号[]的数据,测试报了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

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


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

ECMAScript6入门

ECMAScript6入门

阮一峰 / 电子工业出版社 / 2014-8 / 49.00元

《ECMAScript6入门》全面介绍了ECMAScript6新引入的语法特性,覆盖了ECMAScript6与ECMAScript5的所有不同之处,对涉及的语法知识给予了详细介绍,并给出了大量简洁易懂的示例代码。 《ECMAScript6入门》为中级难度,适合已有一定JavaScript语言基础的读者,用来了解这门语言的最新发展;也可当作参考手册,查寻新增的语法点。一起来看看 《ECMAScript6入门》 这本书的介绍吧!

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

URL 编码/解码
URL 编码/解码

URL 编码/解码

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具