
一、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.Fileimport 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()
}
}
}
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)