J2EE中XML配置文件的读取处理
发布日期:2021-06-24 06:24:18 浏览次数:4 分类:技术文章

本文共 3942 字,大约阅读时间需要 13 分钟。

  在学习编程的过程中,我觉得不止要获得课本的知识,更多的是通过学习技术知识提高解决问题的能力,这样我们才能走在最前方,本文主要讲述J2EE中XML配置文件的读取处理,更多Java专业知识,广州疯狂java培训为你讲解;

  Java和XML是黄金组合,网上已经有很多文章介绍,XML作为电子商务中数据交换,已经有其不可替代的作用,但是在平时系统开发中,我们不一定都用到数据交换,是不是无法使用XML了?

  当然不是,现在已经有一个新趋势,Java程序的配置文件都开始使用XML格式,以前是使用类似Windows的INI格式(Java中也有Propertiesy这样的类专门处理这样的属性配置文件)。使用XML作为Java的配置文件有很多好处,从Tomcat的安装配置文件和J2EE的配置文件中,我们已经看到XML的普遍应用,让我们也跟随流行趋势用XML武装起来。

  现在关键是如何读取XML配置文件?有好几种XML解析器:主要有DOM和SAX,在Apache的XML项目组中,目前有Xerces Xalan Cocoon几个开发XML相关技术的project.Tomcat本身使用的是Sun的JAXP,而其XSL Taglib project中使用Xerces解析器。

  好了,上面都是比较烦人的理论问题,还是赶快切入XML的配置文件的读取吧。在我们的程序中,通常要有一些根据主机环境确定的变量。比如数据库访问用户名和密码,不同的主机可能设置不一样。只要更改XML配置文件,就可以正常运行。

  ﹤myenv﹥

  ﹤datasource﹥

  ﹤dbhost﹥localhost﹤/dbhost﹥

  ﹤dbname﹥sqlname﹤/dbname﹥

  ﹤dbuser﹥username﹤/dbuser﹥

  ﹤dbpassword﹥password﹤/dbpassword﹥

  ﹤/datasource﹥

  ﹤/myenv﹥

  上面这个myenv.xml配置文件一般是放在tomcat的WEB-INF/classes目录下。

  我们编制一个Java程序直接读取,将dbhost dbuser dbpassword提取出来供其他程序访问数据库用。

  目前使用SAX比较的多,与DOM主要区别是SAX是一行一行读取XML文件进行分析,适合比较大文件,DOM是一次性读入内存,显然不能对付大文件。这里我们使用SAX解析,由于SAX解析器不断在发展,网上有不少文章是针对老版本的。如果你使用JDK1.4 ,可以参考 使用SAX处理XML文档 一文。这里的程序是根据其改进并且经过实践调试得来的。

  对上面myenv.xml读取的Java程序:

  import org.xml.sax.Attributes;

  import org.xml.sax.helpers.DefaultHandler;

  import org.xml.sax.SAXException;

  import java.util.Properties;

  //使用DefaultHandler的好处是不必陈列出所有方法,

  public class ConfigParser

  extends DefaultHandler

  {

  定义一个Properties 用来存放

  dbhost dbuser dbpassword的值

  private Properties props;

  private String currentSet;

  private String currentName;

  private StringBuffer

  currentValue = new StringBuffer();

  //构建器初始化props

  public ConfigParser()

  {

  this.props = new Properties();

  }

  public Properties getProps()

  {

  return this.props;

  }

  //定义开始解析元素的方法。这里是将﹤xxx﹥中的名称xxx提取出来。

  public void startElement

  (String uri, String localName,

  String qName, Attributes attributes)

  throws SAXException

  {

  currentValue.delete(0, currentValue.length());

  this.currentName =qName;

  }

  //这里是将﹤xxx﹥﹤/xxx﹥之间的值加入到currentValue

  public void characters(char[] ch,

  int start, int length) throws SAXException

  {

  currentValue.append

  (ch, start, length);

  }

  //在遇到﹤/xxx﹥结束后,将之前的名称和值一一对应保存在props中

  public void endElement(String uri,

  String localName, String qName)

  throws SAXException

  {

  props.put(qName.toLowerCase(),

  currentValue.toString().trim());

  }

  }

  上面的这个解析程序比较简单吧? 其实解析XML就是这么简单。

  现在我们已经将dbhost dbuser dbpassword的值localhost sqlname username password提取了出来。但是这只是在在解析器内部,我们的程序还不能访问。需要再编制一个程序。

  import java.util.Properties;

  import javax.xml.parsers.SAXParser;

  import javax.xml.parsers.SAXParserFactory;

  import java.net.URL;

  public class ParseXML

  {

  //定义一个Properties用来存放 dbhost dbuser dbpassword的值

  private Properties props;

  //这里的props

  public Properties getProps()

  {

  return this.props;

  }

  public void parse(String filename)

  throws Exception {

  //将我们的解析器对象化

  ConfigParser handler = new ConfigParser();

  //获取SAX工厂对象

  SAXParserFactory factory= SAXParserFactory.newInstance();

  factory.setNamespaceAware(false);

  factory.setValidating(false);

  //获取SAX解析

  SAXParser parser= factory.newSAXParser();

  //得到配置文件myenv.xml所在目录。tomcat中是在WEB-INF/classes

  //下例中BeansConstants是用来存放xml文件中配置信息的类,可以自己代替或定义

  URL confURL = BeansConstants.class.

  getClassLoader().getResource(filename);

  try

  {

  //将解析器和解析对象myenv.xml联系起来,开始解析

  parser.parse(confURL.toString(), handler);

  //获取解析成功后的属性以后我们其他应用程序只要调用本程序的props就可以提取出属性名称和值了

  props = handler.getProps();

  }finally{

  factory=null;

  parser=null;

  handler=null;

  }

  }

  }

  由于我们的XML文件是使用最简单的形式,因此解析器相对简单,但是这已经足够对付我们的配置文件了。

  判断一个程序系统的先进性,我们先看看他的配置文件,如果还在使用老套的xxx=123这样类似.ini的文件,我们也许会微微一笑,他又落伍了.....

  疯狂Java培训专注软件开发培训,提升学员就业能力,重点提升实践动手能力。没有工作经验的学员,在疯狂java,通过大量全真经典企业级项目进行集中培训,课上讲师讲解和课下项目练习课上课下双管齐下,学员通过数月培训都可获得1-2年的工作经验,进而在同类的求职者中脱颖而出。疯狂Java培训让你体会java编程的快乐,项目开发的兴奋,成就感,通过短短几个月的时间,让你在半年的时间内掌握8-10万的代码量,掌握Java核心技术,迅速成为技能型的现代化高端人才,迅速获得高薪就业!

 

转载于:https://www.cnblogs.com/gojava/p/3330537.html

转载地址:https://blog.csdn.net/weixin_30896763/article/details/95144041 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!

上一篇:Java中的动态代理模式
下一篇:VUE中实现iview的图标效果时遇到的一个问题

发表评论

最新留言

表示我来过!
[***.240.166.169]2024年04月10日 20时13分57秒