簡析JAVA中的XML編程
發(fā)表時間:2024-02-08 來源:明輝站整理相關(guān)軟件相關(guān)文章人氣:
[摘要]XML作為全球通用的結(jié)構(gòu)化語言,越來越受人們青睞,各種開發(fā)平臺(比如Microsoft Studio系列、Oracle系列、Inprise Borland系列等)也都把支持XML開發(fā)作為產(chǎn)品特色之一 。由于筆者所從事的電子政務(wù)開發(fā)較早的引入了XML,所以嘗到了許多甜頭,在許多項(xiàng)目中利用XML數(shù)據(jù)交...
XML作為全球通用的結(jié)構(gòu)化語言,越來越受人們青睞,各種開發(fā)平臺(比如Microsoft Studio系列、Oracle系列、Inprise Borland系列等)也都把支持XML開發(fā)作為產(chǎn)品特色之一 。由于筆者所從事的電子政務(wù)開發(fā)較早的引入了XML,所以嘗到了許多甜頭,在許多項(xiàng)目中利用XML數(shù)據(jù)交換信息,省去了許多麻煩事,不用制定繁鎖的數(shù)據(jù)格式,利用XML數(shù)據(jù)易于表達(dá),也利于一線開發(fā)者跟蹤調(diào)試。
在XML應(yīng)用中,最常用也最實(shí)用的莫過于XML文件的讀寫,所以筆者通過一個簡單的XML文件讀寫來作簡要分析?梢栽谌魏挝谋揪庉嬈髦邢冉⑷缦陆Y(jié)構(gòu)的XML文件,類似于HTML結(jié)構(gòu),但XML語義比較嚴(yán)格,起始標(biāo)記必須配對,比如"〈學(xué)生花名冊〉"與"〈/學(xué)生花名冊〉"對應(yīng),空格多少可不必在意,但一般都以縮格形式書寫,便于閱讀。把此文件命名為Input.xml,可以在任何支持XML的瀏覽器中打開測試一下,如果輸入正確,在瀏覽中可以看到此文件的樹形表示結(jié)構(gòu)。如果您還對XML結(jié)構(gòu)感到比較陌生,建議先看看《簡析Delphi中的XML編程》一文中關(guān)于XML文件的說明。
<?xml version="1.0" encoding="GB2312"?>
<學(xué)生花名冊>
。紝W(xué)生 性別 = "男">
。夹彰纠钊A</姓名>
。寄挲g>14</年齡>
<電話>6287555</電話>
。/學(xué)生>
。紝W(xué)生 性別 = "男">
。夹彰緩埲/姓名>
<年齡>16</年齡>
。茧娫挘8273425</電話>
。/學(xué)生>
</學(xué)生花名冊>
準(zhǔn)備工作做完后,接著就開始寫實(shí)質(zhì)性的JAVA代碼了。為保存從XML文件讀入的信息,需要先建一個簡單的Bean來保存學(xué)生信息,命名為StudentBean,代碼如下所示:
public class StudentBean {
private String sex; file://學(xué)生性別
private String name; file://學(xué)生姓名
private int age; file://學(xué)生年齡
private String phone; file://電話號碼
public void setSex(String s) {
sex = s;
}
public void setName(String s) {
name = s;
}
public void setAge(int a) {
age = a;
}
public void setPhone(String s) {
phone = s;
}
public String getSex() {
return sex;
}
public String getName() {
return name;
}
public int getAge() {
return age;
}
public String getPhone() {
return phone;
}
}
之后寫XML的測試類,筆者把這個類命名為XMLTest,為了讀寫XML文件,需要導(dǎo)入如下JAVA包,"http://"后為注釋說明,筆者的環(huán)境是JDK 1.3.1_04,在JDK 1.4.0中測試也通過,XML解釋器用Apache的Crimson,可以到Apache主頁去下載。
import java.io.*; file://Java基礎(chǔ)包,包含各種IO操作
import java.util.*; file://Java基礎(chǔ)包,包含各種標(biāo)準(zhǔn)數(shù)據(jù)結(jié)構(gòu)操作
import javax.xml.parsers.*; file://XML解析器接口
import org.w3c.dom.*; file://XML的DOM實(shí)現(xiàn)
import org.apache.crimson.tree.XmlDocument;//寫XML文件要用到
[page_break]
為了保存多個學(xué)生信息,還得借助一個集合類(并不是單純意義上的集合,JAVA中的集合是集合框架的概念,包含向量、列表、哈希表等),這里采用Vector向量類。定義在XMLTest測試類中,命名為student_Vector。然后定義兩個方法readXMLFile和writeXMLFile,實(shí)現(xiàn)讀寫操作。代碼如下:
private void readXMLFile(String inFile) throws Exception {
file://為解析XML作準(zhǔn)備,創(chuàng)建DocumentBuilderFactory實(shí)例,指定DocumentBuilder
DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
DocumentBuilder db = null;
try {
db = dbf.newDocumentBuilder();
} catch (ParserConfigurationException pce) {
System.err.println(pce); file://出異常時輸出異常信息,然后退出,下同
System.exit(1);
}
Document doc = null;
try {
doc = db.parse(inFile);
} catch (DOMException dom) {
System.err.println(dom.getMessage());
System.exit(1);
} catch (IOException ioe) {
System.err.println(ioe);
System.exit(1);
}
file://下面是解析XML的全過程,比較簡單,先取根元素"學(xué)生花名冊"
Element root = doc.getDocumentElement();
file://取"學(xué)生"元素列表
NodeList students = root.getElementsByTagName("學(xué)生");
for (int i = 0; i < students.getLength(); i++) {
file://依次取每個"學(xué)生"元素
Element student = (Element) students.item(i);
file://創(chuàng)建一個學(xué)生的Bean實(shí)例
StudentBean studentBean = new StudentBean();
file://取學(xué)生的性別屬性
studentBean.setSex(student.getAttribute("性別"));
file://取"姓名"元素,下面類同
NodeList names = student.getElementsByTagName("姓名");
if (names.getLength() == 1) {
Element e = (Element) names.item(0);
Text t = (Text) e.getFirstChild();
studentBean.setName(t.getNodeValue());
}
NodeList ages = student.getElementsByTagName("年齡");
if (ages.getLength() == 1) {
Element e = (Element) ages.item(0);
Text t = (Text) e.getFirstChild();
studentBean.setAge(Integer.parseInt(t.getNodeValue()));
}
NodeList phones = student.getElementsByTagName("電話");
if (phones.getLength() == 1) {
Element e = (Element) phones.item(0);
Text t = (Text) e.getFirstChild();
studentBean.setPhone(t.getNodeValue());
}
student_Vector.add(studentBean);
}
}
private void writeXMLFile(String outFile) throws Exception {
file://為解析XML作準(zhǔn)備,創(chuàng)建DocumentBuilderFactory實(shí)例,指定DocumentBuilder
DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
DocumentBuilder db = null;
try {
db = dbf.newDocumentBuilder();
} catch (ParserConfigurationException pce) {
System.err.println(pce);
System.exit(1);
}
Document doc = null;
doc = db.newDocument();
file://下面是建立XML文檔內(nèi)容的過程,先建立根元素"學(xué)生花名冊"
Element root = doc.createElement("學(xué)生花名冊");
file://根元素添加上文檔
doc.appendChild(root);
file://取學(xué)生信息的Bean列表
for (int i = 0; i < student_Vector.size(); i++) {
file://依次取每個學(xué)生的信息
StudentBean studentBean = (StudentBean) student_Vector.get(i);
file://建立"學(xué)生"元素,添加到根元素
Element student = doc.createElement("學(xué)生");
student.setAttribute("性別", studentBean.getSex());
root.appendChild(student);
file://建立"姓名"元素,添加到學(xué)生下面,下同
Element name = doc.createElement("姓名");
student.appendChild(name);
Text tName = doc.createTextNode(studentBean.getName());
name.appendChild(tName);
Element age = doc.createElement("年齡");
student.appendChild(age);
Text tAge = doc.createTextNode(String.valueOf(studentBean.getAge()));
age.appendChild(tAge);
Element phone = doc.createElement("電話");
student.appendChild(phone);
Text tPhone = doc.createTextNode(studentBean.getPhone());
phone.appendChild(tPhone);
}
file://把XML文檔輸出到指定的文件
FileOutputStream outStream = new FileOutputStream(outFile);
OutputStreamWriter outWriter = new OutputStreamWriter(outStream);
((XmlDocument) doc).write(outWriter, "GB2312");
outWriter.close();
outStream.close();
}
最后加入測試主函數(shù),如下:
public static void main(String[] args) throws Exception {
file://建立測試實(shí)例
XMLTest xmlTest = new XMLTest();
file://初始化向量列表
xmlTest.student_Vector = new Vector();
System.out.println("開始讀Input.xml文件");
xmlTest.readXMLFile("Input.xml");
System.out.println("讀入完畢,開始寫Output.xml文件");
xmlTest.writeXMLFile("Output.xml");
System.out.println("寫入完成");
}
保存好StudentBean和XMLTest,把Input.xml保存到工作目錄下。如果您輸入很仔細(xì),沒敲錯字母的話,可以看到"寫入完成"了,去瞧瞧Output.xml文件和Input.xml文件是不是一樣吧。