使用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"):""));
	}
}




  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值