java中怎么样读取xml里的数据库

java中怎么样读取xml里的数据库,第1张

最简单的方法,用XML格式的Properties。 输出: import java.io.FileOutputStreamimport java.io.OutputStreamimport java.io.IOExceptionimport java.util.Propertiespublic class PropertiesSaveTest { public PropertiesSaveTest() {...

在我们的程序中,通常要有一些根据主机环境确定的变量.比如数据库访问用户名和密码,不同的主机可能设置不一样.只要更改XML配置文件,就可以正常运行.

localhost

sqlname

username

password

上面这个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提取出来.

public void startElement(String uri, String localName, String qName, Attributes attributes)

throws SAXException {

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

this.currentName =qName

}

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

public void characters(char[] ch, int start, int length) throws SAXException {

currentValue.append(ch, start, length)

}

//在碰到结束后,将之前的名称和值一一对应保存在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文件是使用最简单的形式 ,因此解析器相对简单,但是这已经足够对付我们的配置文件了.

语法问题,这一句:

<Lay class="ui.LayBackground "x="0" y="0" w="0" h="0"/>

出了问题,注意写完class属性的值后输入一个空格!

属性与属性之间要有空格间隔!所以应该这么写:

<Lay class="ui.LayBackground" x="0" y="0" w="0" h="0"/>


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/6733281.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-03-27
下一篇 2023-03-27

发表评论

登录后才能评论

评论列表(0条)

保存