项目数据库中出现许多值为中括号[]的数据,测试报了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;
1
|
JSON json =xmlSerializer.read(xml);
|
这个方法出现的问题便是会将空值转化为[],使用 json.get(value).getclass 获取[]的类型可以发现:json-lib将空值识别为了jsonarray类型而不是string,而jsonarray的tostring方法被重写为[,,,,]
如果依然要使用这个方法,可以做如下修改,在使用getString()方法获取由xml转化的json对象值时,先判断类型是是否为string再获取。
1
|
json.get(value) instanceof String ? json.getString(value): ""
|
2、org.json 转json :
1
|
org.json.JSONObject jsonObj = org.json.XML.toJSONObject(xml);
|
不会生成[]值,但是会保留根标签(标准XML文档有且只有一个根标签,所谓的根标签就是一对<根标签></根标签>包含其他全部标签),而一般根标签对数据而言是没有意义的,所以你如果需要做处理的话
1
|
jsonObj.get( "root" );
|
下面是测试代码:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
|
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
大家可以根据自身需求选择使用哪种方法
原文链接:http://blog.csdn.net/rain_xia_/article/details/51065135