怎么在java类中加载xml文件

怎么在java类中加载xml文件,第1张

JAVA与XML文件,可以说是软件开发的“黄金搭档”,而如何使用JAVA完成对XML文件的读取,是我们首先要解决的问题。

一、XML文件

这个示例文件包括了用来打开ORACLE数据库的各种参数

<?xml version="1.0" encoding="UTF-8"?>

<dbmsg>

<dbinfo>

<drivername>oracle.jdbc.driver.OracleDriver</drivername>

<sConnStr>jdbc:oracle:thin:@11.88.225.80:1521:VOUCHERDB</sConnStr>

<username>SYS AS SYSDBA</username>

<password>voucherdb</password>

</dbinfo>

</dbmsg>

二、编写类名为ReadXml的类,用于解析XML文件

我们要在应用程序中打开数据库,就必须完成对该文件中drivername、sConnStr、username、password的读取,通过查找有关资料,笔者编制了以下程序,用于读取文件名为filename的XML文件。

package voucher.basic

import java.io.FileInputStream

import java.io.FileNotFoundException

import java.io.IOException

import java.io.InputStream

import javax.xml.parsers.DocumentBuilder

import javax.xml.parsers.DocumentBuilderFactory

import javax.xml.parsers.ParserConfigurationException

import org.w3c.dom.Document

import org.w3c.dom.Element

import org.w3c.dom.Node

import org.w3c.dom.NodeList

import org.xml.sax.SAXException

public class ReadXml {

private String drivername

private String sConnStr

private String username

private String password

public String getDrivername() {

return drivername

}

public String getSConnStr() {

return sConnStr

}

public String getUsername() {

return username

}

public String getPassword() {

return password

}

public void setDrivername(String drivername) {

this.drivername = drivername

}

public void setSConnStr(String connStr) {

sConnStr = connStr

}

public void setUsername(String username) {

this.username = username

}

public void setPassword(String password) {

this.password = password

}

public ReadXml(String fileName){

DocumentBuilderFactory domfac=DocumentBuilderFactory.newInstance()

try {

DocumentBuilder dombuilder=domfac.newDocumentBuilder()

InputStream is=new FileInputStream(fileName)

Document doc=dombuilder.parse(is)

Element root=doc.getDocumentElement()

NodeList dbinfo=root.getChildNodes()

if(dbinfo!=null){

for(int i=0i<dbinfo.getLength()i++){

Node db=dbinfo.item(i)

for(Node node=db.getFirstChild()node!=nullnode=node.getNextSibling()){

if(node.getNodeType()==Node.ELEMENT_NODE){

if(node.getNodeName().equals("drivername")){

setDrivername(node.getFirstChild().getNodeValue())

}

if(node.getNodeName().equals("sConnStr")){

setSConnStr(node.getFirstChild().getNodeValue())

}

if(node.getNodeName().equals("username")){

setUsername(node.getFirstChild().getNodeValue())

}

if(node.getNodeName().equals("password")){

setPassword(node.getFirstChild().getNodeValue())

}

}

}

}

}

} catch (ParserConfigurationException e) {

// TODO Auto-generated catch block

e.printStackTrace()

} catch (FileNotFoundException e) {

// TODO Auto-generated catch block

e.printStackTrace()

} catch (SAXException e) {

// TODO Auto-generated catch block

e.printStackTrace()

} catch (IOException e) {

// TODO Auto-generated catch block

e.printStackTrace()

}

}

}

这个以ReadXml命名的类,使用了参数为文件名的构造方法,用户只要将配置文件我名称传递给该方法,就可以完成对XML文件的解析,进而完成对相应参数数的读取。

三、如何获取XML文件全路径并读取配置参数

获取XML文件全路径的方法有两个,一是在servlet中获取,二是在单独的JAVA类中获取。

1.在servlet中获取XML文件的全路径并读取配置参数

程序片段String dirPath = getServletContext().getRealPath( "/WEB-INF")

String fileName = dirPath + "/conn.xml"

ReadXml xm = new ReadXml(fileName)

String DriverName = xm.getDrivername()

String connStr = xm.getSConnStr()

String user = xm.getUsername()

String pas = xm.getPassword()

将这段程序添加到servlet中dopost()之后即可完成参数的读取

2.在单独的JAVA类中获取全路径并读取配置参数

程序片段

String dirpath = System.getProperty("user.dir")

String xmlFile = dirpath + "/WebRoot/WEB-INF/conn.xml"

ReadXml rdxml = new ReadXml(xmlFile)

String driverName = rdxml.getDrivername()

String sConnStr = rdxml.getSConnStr()

String userName = rdxml.getUsername()

String passWord = rdxml.getPassword()

注:配置文件conn.xml保存在webroot/WEB-INF目录中。

一般旧的处理方法是,先向记录里插入一个空的BLOB,然后再读取这条数据,用驱动里对应BLOB类型进行IO读写,比较繁琐,但自从ojdbc14.jar版本驱动之后,可以直接使用String类型进行映射,不用写IO流 *** 作,非常方便,当然旧的驱动就不行了,楼主可以试一下

不说废话直接上代码,下面是要读取的xml文件:

<?xml version="1.0" encoding="UTF-8"?>

<PERSON>

  <NAME>a1</NAME>

  <ADDRESS>b1</ADDRESS>

  <TEL>c1</TEL>

  <FAX>d1</FAX>

  <EMAIL>e1</EMAIL>

</PERSON>

下面是读取xml文件的java代码,在数据库中建一张和xml文件字段对应的表,将读取的数据插入到表中。如果数据插入不会,欢迎继续追问:

import java.io.File

import javax.xml.parsers.DocumentBuilder

import javax.xml.parsers.DocumentBuilderFactory

import org.w3c.dom.Document

import org.w3c.dom.Element

import org.w3c.dom.NodeList

public class Test {

public static void main(String[] args) throws Exception{

System.out.println("22")

DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance()

DocumentBuilder db = dbf.newDocumentBuilder()

Document document = db.parse(new File("candidate.xml"))

NodeList list = document.getElementsByTagName("PERSON")

for(int i = 0 i < list.getLength() i++)

{

Element element = (Element)list.item(i)

String content = element.getElementsByTagName("NAME").item(0).getFirstChild().getNodeValue()

            content = element.getElementsByTagName("ADDRESS").item(0).getFirstChild().getNodeValue()

            content = element.getElementsByTagName("TEL").item(0).getFirstChild().getNodeValue()

            content = element.getElementsByTagName("FAX").item(0).getFirstChild().getNodeValue()

            content = element.getElementsByTagName("EMAIL").item(0).getFirstChild().getNodeValue()

        }

    }

}


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

原文地址:https://54852.com/bake/7983351.html

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

发表评论

登录后才能评论

评论列表(0条)

    保存