JAVA 实现XML与JSON 相互转换

时间:2021-11-14 18:32:08

原文地址https://blog.csdn.net/congcong68/article/details/39029907

在工作中,经常碰到XML转为JSON或者JSON转为XML,在这过程中有时嵌套很多层,容易错误,我把实现的代码分享出来,希望对有用到的人提供借鉴。

   1.把XML转为JSON格式

  1. <span style="font-size:18px;">@SuppressWarnings("rawtypes")
  2. public static  String xmlToJSON(String xml,int jsonType) {
  3. JSONObject obj = new JSONObject();
  4. try {
  5. InputStream is = new ByteArrayInputStream(xml.getBytes("utf-8"));
  6. SAXBuilder sb = new SAXBuilder();
  7. Document doc = sb.build(is);
  8. Element root = doc.getRootElement();
  9. Map map=iterateElement(root);
  10. obj.put(root.getName(),map);
  11. return obj.toString();
  12. } catch (Exception e) {
  13. e.printStackTrace();
  14. return null;
  15. }
  16. }
  17. @SuppressWarnings({ "unchecked", "rawtypes" })
  18. private static Map  iterateElement(Element root) {
  19. List childrenList = root.getChildren();
  20. Element element = null;
  21. Map map = new HashMap();
  22. List list = null;
  23. for (int i = 0; i < childrenList.size(); i++) {
  24. list = new ArrayList();
  25. element = (Element) childrenList.get(i);
  26. if(element.getChildren().size()>0){
  27. if(root.getChildren(element.getName()).size()>1){
  28. if (map.containsKey(element.getName())) {
  29. list = (List) map.get(element.getName());
  30. }
  31. list.add(iterateElement(element));
  32. map.put(element.getName(), list);
  33. }else{
  34. map.put(element.getName(), iterateElement(element));
  35. }
  36. }else {
  37. if(root.getChildren(element.getName()).size()>1){
  38. if (map.containsKey(element.getName())) {
  39. list = (List) map.get(element.getName());
  40. }
  41. list.add(element.getTextTrim());
  42. map.put(element.getName(), list);
  43. }else{
  44. map.put(element.getName(), element.getTextTrim());
  45. }
  46. }
  47. }
  48. return map;
  49. }
  50. public static void main(String[] args) throws ParseException
  51. {
  52. String xml="<ROOT>"+
  53. "<Status>00</Status>"+
  54. "<ErrorMsg></ErrorMsg>"+
  55. "<Data>"+
  56. "<Row>"+
  57. "<PERSONID>35020500200610000000000701355116</PERSONID>"+
  58. "<XM>吴聪楠</XM><SFZH>350624198908052530</SFZH>"+
  59. "</Row>"+
  60. "<Row>"+
  61. "<PERSONID>35020500200610000000000701355117</PERSONID>"+
  62. "<XM>吴聪楠2</XM><SFZH>350624198908052531</SFZH>"+
  63. "</Row>"+
  64. "</Data>"+
  65. "</ROOT>";
  66. String str=Xml2JsonUtil.xmlToJSON(xml,1);
  67. System.out.println(str);
  68. }</span>

原来的格式:

<ROOT><Status>00</Status><ErrorMsg></ErrorMsg><Data><Row><PERSONID>35020500200610000000000701355116</PERSONID><XM>吴聪楠</XM><SFZH>350624198908052530</SFZH></Row><Row><PERSONID>35020500200610000000000701355117</PERSONID><XM>吴聪楠2</XM><SFZH>350624198908052530</SFZH></Row></Data></ROOT>

转换完的格式:

<span style="font-size:18px;">{"ROOT":{"Data":{"Row":[{"SFZH":"350624198908052530","XM":"吴聪楠","PERSONID":"35020500200610000000000701355116"},{"SFZH":"350624198908052530","XM":"吴聪楠2","PERSONID":"35020500200610000000000701355117"}]},"Status":"00","ErrorMsg":""}}</span>

  2.JSON 转换为XML格式

  1. <span style="font-size:18px;">public static  String JsonToXml(Object json)
  2. {
  3. if(json==null){
  4. return null;
  5. }else{
  6. Element elements=new Element("xml");
  7. getXMLFromObject(json,"xml",elements);
  8. XMLOutputter xmlOut = new XMLOutputter();
  9. String res=xmlOut.outputString(elements);
  10. return res;
  11. }
  12. }
  13. private static void getXMLFromObject(Object obj,String tag,Element parent)
  14. {
  15. if(obj==null)
  16. return;
  17. Element child;
  18. String eleStr;
  19. Object childValue;
  20. if(obj instanceof JSONObject)
  21. {
  22. JSONObject jsonObject=(JSONObject)obj;
  23. for(Object temp:jsonObject.keySet())
  24. {
  25. eleStr=temp.toString();
  26. childValue=jsonObject.get(temp);
  27. child=new Element(eleStr);
  28. if(childValue instanceof JSONArray)
  29. getXMLFromObject(childValue,eleStr,parent,count);
  30. else{
  31. parent.addContent(child);
  32. getXMLFromObject(childValue,eleStr,child,count);
  33. }
  34. }
  35. }else if(obj instanceof JSONArray){
  36. JSONArray jsonArray=(JSONArray)obj;
  37. for(int i=0;i<jsonArray.size();i++)
  38. {
  39. childValue=jsonArray.get(i);
  40. child=new Element(tag);
  41. parent.addContent(child);
  42. getXMLFromObject(childValue,tag,child,count);
  43. }
  44. }else if(obj instanceof Date){
  45. SimpleDateFormat sf=new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
  46. parent.setText(sf.format((Date)obj));
  47. }else{
  48. parent.setText(obj.toString());
  49. }
  50. }
  51. public static void main(String[] args) throws ParseException
  52. {
  53. JSONObject rootObject=new JSONObject();
  54. JSONArray dataArray=new JSONArray();
  55. JSONObject dataObject1=new JSONObject();
  56. dataObject1.put("PERSONID", "35020500200610000000000701355117");
  57. dataObject1.put("XM", "吴聪楠");
  58. dataObject1.put("SFZH","350624198908052530");
  59. dataArray.add(dataObject1);
  60. JSONObject dataObject2=new JSONObject();
  61. dataObject2.put("PERSONID", "35020500200610000000000701355116");
  62. dataObject2.put("XM", "吴聪楠2");
  63. dataObject2.put("SFZH","350624198908052531");
  64. dataArray.add(dataObject2);
  65. JSONObject dataRootObject=new JSONObject();
  66. dataRootObject.put("Row", dataArray);
  67. JSONObject dataObject=new JSONObject();
  68. dataObject.put("Status", "00");
  69. dataObject.put("ErrorMsg", "");
  70. dataObject.put("Data",dataRootObject);
  71. rootObject.put("ROOT", dataObject);
  72. System.out.println(rootObject.toString());
  73. System.out.println(JsonToXml(rootObject));
  74. }</span>

  原来的格式:    

{"ROOT":{"Status":"00","ErrorMsg":"","Data":{"Row":[{"PERSONID":"35020500200610000000000701355117","XM":"吴聪楠","SFZH":"350624198908052530"},{"PERSONID":"35020500200610000000000701355116","XM":"吴聪楠2","SFZH":"350624198908052531"}]}}}

转换完的格式:

<ROOT><Status>00</Status><ErrorMsg></ErrorMsg><Data><Row><PERSONID>35020500200610000000000701355117</PERSONID><XM>吴聪楠</XM><SFZH>350624198908052530</SFZH></Row><Row><PERSONID>35020500200610000000000701355116</PERSONID><XM>吴聪楠2</XM><SFZH>350624198908052531</SFZH></Row></Data></ROOT>