一个用Dom4j解析xml的例子

一、测试用的em.xml
<?xml version="1.0" encoding="GB2312"?>
 <EW cmd="login" mod="Login" version="6.0">
   <Source uns="" type="user"/>
   <Username>zhangzhiyun@hp</Username>
   <Password>111111</Password>
  <Version>6.01.06.00</Version>
</EW>

 

二、Dom4jTest.java

 import java.io.BufferedReader;
 import java.io.BufferedWriter;
 import java.io.File;
 import java.io.FileReader;
 import java.io.FileWriter;
 import java.io.IOException;
 import org.apache.log4j.Logger;
 import org.dom4j.Attribute;
 import org.dom4j.DocumentException;
 import org.dom4j.DocumentHelper;
 import org.dom4j.Element;
 /**
  * @author julysea
  *
  * 一个用Dom4j解析xml的例子
  *
  */
 public class Dom4jTest {
   private static final Logger logger = Logger.getLogger(Dom4jTest.class);
    public static void main(String[] args) throws IOException,
       DocumentException {
         BufferedReader reader=new BufferedReader(new FileReader("ew.xml"));
         String tempStr;
         String ewXml="";
         while((tempStr=reader.readLine())!=null) {
             ewXml=ewXml+tempStr;
             logger.debug(tempStr);
         }
        Element root = null;
         root = DocumentHelper.parseText(ewXml).getRootElement();
         Attribute rootCmd=root.attribute("cmd");
         Attribute rootVersion=root.attribute("version");
         logger.debug("rootNmae = "+root.getName());
         logger.debug("EW'cmd = "+rootCmd.getValue());
         logger.debug("EW'version = "+rootVersion.getValue());
         Element usrName=root.element("Username");
         logger.debug("EW.Username value = "+usrName.getTextTrim());
         Element source=root.element("Source");
         Attribute sourceUns=source.attribute("uns");
         logger.debug("EW.Source'uns="+sourceUns.getValue());
         Attribute sourceType=source.attribute("type");
         logger.debug("EW.Source'type = "+sourceType.getValue());
        //创建一个Xml文件
        Element user=DocumentHelper.createElement("User");
        user.addAttribute("type", "user");
        user.addElement("name").addAttribute("type", "PinYin").setText("Julysea");
        user.addElement("age").setText("29");
        String oneXml=user.asXML();
        
        BufferedWriter out=new BufferedWriter(new FileWriter("oneXml.xml"));
         out.write(oneXml);
         out.close();
     }
 }

 

三、运行:将log4j.properties文件与Dom4jTest.java放同一目录下编译运行,以下是输出结果:
log4e.log文件内容:

2006-04-04 09:16:13,363 [main] DEBUG Dom4jTest - <?xml version="1.0" encoding="GB2312"?>
2006-04-04 09:16:13,373 [main] DEBUG Dom4jTest - <EW cmd="login" mod="Login" version="6.0">
2006-04-04 09:16:13,373 [main] DEBUG Dom4jTest -   <Source uns="" type="user"/>
2006-04-04 09:16:13,373 [main] DEBUG Dom4jTest -   <Username>zhangzhiyun@hp</Username>
2006-04-04 09:16:13,373 [main] DEBUG Dom4jTest -   <Password>111111</Password>
2006-04-04 09:16:13,373 [main] DEBUG Dom4jTest -   <Version>6.01.06.00</Version>
2006-04-04 09:16:13,373 [main] DEBUG Dom4jTest - </EW>
2006-04-04 09:16:13,594 [main] DEBUG Dom4jTest - rootNmae = EW
2006-04-04 09:16:13,594 [main] DEBUG Dom4jTest - EW'cmd = login
2006-04-04 09:16:13,594 [main] DEBUG Dom4jTest - EW'version = 6.0
2006-04-04 09:16:13,594 [main] DEBUG Dom4jTest - EW.Username value = zhangzhiyun@hp
2006-04-04 09:16:13,594 [main] DEBUG Dom4jTest - EW.Source'uns=
2006-04-04 09:16:13,594 [main] DEBUG Dom4jTest - EW.Source'type = user

oneXml.xml的内容:

<User type="user"><name type="PinYin">Julysea</name><age>29</age></User>

四、log4j日志配置文件:log4j.properties

log4j.rootCategory=ConApp, FileApp
# ConApp is set to be a ConsoleAppender.
log4j.appender.ConApp=org.apache.log4j.ConsoleAppender
log4j.appender.ConApp.Target=System.out
log4j.appender.ConApp.layout=org.apache.log4j.PatternLayout
log4j.appender.ConApp.layout.ConversionPattern=%d{ABSOLUTE} %5p %c{1}:%L - %m%n
# FileApp
log4j.appender.FileApp=org.apache.log4j.RollingFileAppender
log4j.appender.FileApp.File=./log4e.log
log4j.appender.FileApp.MaxFileSize=500KB
# Keep one backup file
log4j.appender.FileApp.MaxBackupIndex=1
log4j.appender.FileApp.layout=org.apache.log4j.PatternLayout
log4j.appender.FileApp.layout.ConversionPattern=%d [%t] %-5p %c - %m%n

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值