JDom读写XML(代码)

本文介绍了一种利用Java库JDOM进行XML文件读写的实现方法。具体包括创建`ConfigOperater`类来加载XML配置文件,通过遍历`TargetDB`元素节点获取数据库配置信息,并将这些信息存储为`Database`对象;此外还展示了如何更新XML配置文件,通过创建新的`TargetDB`元素并设置其属性来反映当前数据库连接设置。
SAXBuilder builder;
Document doc;
Element root;

public ConfigOperater() {
builder = new SAXBuilder();
try {
doc = builder.build(DataUtil.CONFIG_PATH);
root = doc.getRootElement();
}
catch (IOException ex) {
ex.printStackTrace();
}
catch (JDOMException ex) {
ex.printStackTrace();
}
}

//JDom读取XML

public void readConfig() {
List allConfigDB = root.getChildren("TargetDB");
for(int i=0; i Element dbEle = (Element)allConfigDB.get(i);
Database database = new Database(dbEle.getAttributeValue("dbType"),
dbEle.getAttributeValue("id"),dbEle.getAttributeValue("dbIp"),
Integer.parseInt(dbEle.getAttributeValue("dbPort")),dbEle.getAttributeValue("dbName"),
dbEle.getAttributeValue("dbUser"),dbEle.getAttributeValue("dbPwd"),
dbEle.getAttributeValue("dbServer"),dbEle.getAttributeValue("clientLocale"),
dbEle.getAttributeValue("dbLocale"));
DataUtil.ALL_DB.addElement(database);
}
//DataBase db
}

//JDom写入XML

public void writeToConfig() {
Element dbEle = new Element("TargetDB");
dbEle.setAttribute("id", DataUtil.curDB.getDbConName());
dbEle.setAttribute("dbType", DataUtil.curDB.getDBType());
dbEle.setAttribute("dbServer", DataUtil.curDB.getDbServer());
dbEle.setAttribute("dbName", DataUtil.curDB.getDbName());
dbEle.setAttribute("dbUser", DataUtil.curDB.getDbUser());
dbEle.setAttribute("dbPwd", DataUtil.curDB.getDbPwd());
dbEle.setAttribute("dbIp", DataUtil.curDB.getDbIp());
dbEle.setAttribute("dbPort", Integer.toString(DataUtil.curDB.getDbPort()));
dbEle.setAttribute("dbLocale", DataUtil.curDB.getDbLocale());
dbEle.setAttribute("clientLocale", DataUtil.curDB.getClientLocale());

root.addContent(dbEle);
try {
XMLOutputter outPutter = new XMLOutputter();
PrintWriter outWriter = new PrintWriter(new BufferedWriter(new FileWriter(DataUtil.CONFIG_PATH)));
outPutter.output(doc, outWriter);
}
catch (java.io.IOException e) {
e.printStackTrace();
}
}

[@more@]

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/11049438/viewspace-967520/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/11049438/viewspace-967520/

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值