JAVA中解析XML文件

 对XML文件解析配置:
先写一个需要解析的XML文件,本例中用TestConfig.xml,其内容如下:
<?xml version="1.0" encoding="UTF-8"?>
<searchs>

<search type="search1">
<table>REF_COUNTRY</table>
<conditions>
<condition name="代码" type="String">CNTRY_ISO_CD</condition>
<condition name="中文名" type="String">CNTRY_CHN_NM</condition>
<condition name="英文名" type="String">CNTRY_ENG_NM</condition>
</conditions>
<results>
<result name="代码" type="String">CNTRY_ISO_CD</result>
<result name="中文名" type="String">CNTRY_CHN_NM</result>
<result name="英文名" type="String">CNTRY_ENG_NM</result>
</results>
</search>

<search type="search2">
<table>REF_AIRPORT</table>
<conditions>
<condition name="代码" type="String">AIRPORT_IATA_CD</condition>
<condition name="中文名" type="String">AIRPORT_ENG_NM</condition>
<condition name="英文名" type="String">AIRPORT_CHN_NM</condition>
</conditions>
<results>
<result name="代码" type="String">AIRPORT_IATA_CD</result>
<result name="中文名" type="String">AIRPORT_ENG_NM</result>
<result name="英文名" type="String">AIRPORT_CHN_NM</result>
</results>
</search>

</searchs>


新建一个servlet,取名为TestPopConfigServlet,这里要修改其在web.xml文件中注册的内容.
如下:
<servlet>
        <servlet-name>TestPopConfigServlet</servlet-name>
        <servlet-class>com.icss.caac.pnrdest.servlet.TestPopConfigServlet</servlet-class>
        <init-param>
        <param-name>TestConfigXmlName</param-name>
        <param-value>TestConfig.xml</param-value>
 </init-param>
 <load-on-startup>2</load-on-startup>
</servlet>
其中TestConfig.xml是解析的xml文件名,将映射到一个名字TestConfigXmlName,以方便在servlet中取到文件的名字.

然后就是编写servlet的内容: (注意,在调用jdom包的类之前需要把这个包导入到工程,主要逻辑在cXmlToMap(String path)函数中实现.)

package com.icss.caac.pnrdest.servlet;

import java.io.IOException;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.Iterator;
import java.util.List;
import java.util.Map;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;

import org.jdom.Document;
import org.jdom.Element;
import org.jdom.JDOMException;
import org.jdom.input.SAXBuilder;

import com.icss.common.logging.Log;
import com.icss.common.logging.LogFactory;
import com.icss.common.util.Constants;

public class TestPopConfigServlet extends HttpServlet {

    private static Log log = LogFactory.getLog(Constants.COMMON_CONFIGKEY,TestPopConfigServlet.class);
   
 /**
  * Constructor of the object.
  */
 public TestPopConfigServlet() {
  super();
 }

 /**
  * Destruction of the servlet. <br>
  */
 public void destroy() {
  super.destroy();
 }


 public void init() throws ServletException {
  String path = getServletContext().getRealPath("/");
  String fileName =getInitParameter("TestConfigXmlName");
  String filePath=path+"WEB-INF//classes//"+fileName;
  Map map=cXmlToMap(filePath);
  getServletContext().setAttribute("map",map);
  log.debug("加载查询配置成功!!!");
 }
 
 private Map cXmlToMap(String path){
  SAXBuilder sb = new SAXBuilder();
  Document document=null;
  Element element=null;
  String table=null;
  String name=null;
  String type=null;
  String content=null;
  String searchType=null;
  List valueList=new ArrayList();
  List conditionList=new ArrayList();
  List resultList=new ArrayList();
  List list=new ArrayList();
  Iterator it=null;
  Map map=new HashMap();
  
  try {
   document = sb.build(path);
  } catch (JDOMException e) {
  } catch (IOException e) {
  }
  Element rootElement = document.getRootElement();
  Iterator searchIt= rootElement.getChildren("search").iterator();
  while(searchIt.hasNext()){
   element=(Element) searchIt.next();
   //查询类型
   searchType=element.getAttributeValue("type");
   //读取操作的表
   table=element.getChild("table").getText();
            //循环读取查询条件
   it=element.getChild("conditions").getChildren("condition").iterator();
   while(it.hasNext()){
    name=((Element)it.next()).getAttributeValue("name");
    type=((Element)it.next()).getAttributeValue("type");
    content=((Element)it.next()).getText();
    list.add(name);
    list.add(type);
    list.add(content);
    conditionList.add(list);
   }
           //循环读取查询条件
   it=element.getChild("results").getChildren("result").iterator();
   while(it.hasNext()){
    name=((Element)it.next()).getAttributeValue("name");
    type=((Element)it.next()).getAttributeValue("type");
    content=((Element)it.next()).getText();
    list.add(name);
    list.add(type);
    list.add(content);
    resultList.add(list);
   }
   valueList.add(table);
   valueList.add(conditionList);
   valueList.add(resultList);
   map.put(searchType,valueList);
  }
  return map;
 }


}

启动tomcat服务器后,则会调用此servlet自动解析TestConfig.xml文件.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java提供了多种解析XML文件的方法,常见的有以下几种: 1. DOM解析方式:将整个XML文档读入内存,形成一个树形结构,可以对整个XML文档进行增删改查操作。 2. SAX解析方式:采用事件驱动的方式,逐行解析XML文档,对每个元素进行处理,优点是解析速度快,但不能进行修改操作。 3. JAXB解析方式:通过注解方式将Java对象与XML元素进行映射,可以实现Java对象与XML文档的互相转换。 4. StAX解析方式:基于流的方式解析XML文档,可以进行增删改查操作,速度较快,但相对于DOM速度稍慢。 下面是一个使用DOM方式解析XML文档的示例代码: ```java import javax.xml.parsers.DocumentBuilderFactory; import javax.xml.parsers.DocumentBuilder; import org.w3c.dom.Document; import org.w3c.dom.NodeList; import org.w3c.dom.Node; import org.w3c.dom.Element; import java.io.File; public class XMLParser { public static void main(String argv[]) { try { File inputFile = new File("input.xml"); DocumentBuilderFactory dbFactory = DocumentBuilderFactory.newInstance(); DocumentBuilder dBuilder = dbFactory.newDocumentBuilder(); Document doc = dBuilder.parse(inputFile); doc.getDocumentElement().normalize(); System.out.println("Root element :" + doc.getDocumentElement().getNodeName()); NodeList nList = doc.getElementsByTagName("student"); for (int temp = 0; temp < nList.getLength(); temp++) { Node nNode = nList.item(temp); System.out.println("\nCurrent Element :" + nNode.getNodeName()); if (nNode.getNodeType() == Node.ELEMENT_NODE) { Element eElement = (Element) nNode; System.out.println("Student roll no : " + eElement.getAttribute("rollno")); System.out.println("First Name : " + eElement.getElementsByTagName("firstname").item(0).getTextContent()); System.out.println("Last Name : " + eElement.getElementsByTagName("lastname").item(0).getTextContent()); System.out.println("Nick Name : " + eElement.getElementsByTagName("nickname").item(0).getTextContent()); System.out.println("Marks : " + eElement.getElementsByTagName("marks").item(0).getTextContent()); } } } catch (Exception e) { e.printStackTrace(); } } } ``` 以上代码使用DOM方式解析XML文档,首先将XML文件读入内存,然后通过getNodeName()、getAttribute()、getElementsByTagName()等方法获取XML元素的信息。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值