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

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

内容简介:网上能查到的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

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


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

查看所有标签

猜你喜欢:

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

Cracking the Coding Interview

Cracking the Coding Interview

Gayle Laakmann McDowell / CareerCup / 2015-7-1 / USD 39.95

Cracking the Coding Interview, 6th Edition is here to help you through this process, teaching you what you need to know and enabling you to perform at your very best. I've coached and interviewed hund......一起来看看 《Cracking the Coding Interview》 这本书的介绍吧!

SHA 加密
SHA 加密

SHA 加密工具

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

RGB CMYK 互转工具

HEX HSV 转换工具
HEX HSV 转换工具

HEX HSV 互换工具