Java使用DOM4J对XML文件进行增删改查操作
Java进行XML文件操作,代码如下:
package com.founder.mrp.util; import java.io.File;
import java.util.ArrayList;
import java.util.List; import org.dom4j.Document;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;
import org.dom4j.Node; import com.founder.mrp.domain.ClientLoginUser;
import com.founder.mrp.util.md5.MD5; public class XMLOperateUser { /*
* 查询全部xml
* */
public static List<ClientLoginUser> ListClinetLoginUser(String appDir) throws Exception{
File dir = new File(appDir+"\\persons.xml");
if (!dir.exists()) {
dir.createNewFile();
Document dom = DocumentHelper.createDocument();
Element root = dom.addElement("persons");
String dirpath = dir+"";
UtilsForXML.writeToXML(dom, dirpath);
}
String dirPath = dir+"";
Document dom = UtilsForXML.getDocument(dirPath);
Element root = dom.getRootElement();
List<ClientLoginUser> persons = new ArrayList<ClientLoginUser>(); List list = root.elements();
for (int i = 0; i < list.size(); i++) {
Element person = (Element) list.get(i);
ClientLoginUser c = new ClientLoginUser();
String id = person.attributeValue("id");
c.setId(Integer.parseInt(id));
List ll = person.elements();
for (int j = 0; j < ll.size(); j++) {
Element element = (Element) ll.get(j);
if ("publishername".equals(element.getName())) {
String publisherName = element.getText();
c.setPublisherName(publisherName);
}
if ("serverurl".equals(element.getName())) {
String serverurl = element.getText();
c.setServerUrl(serverurl);
}
if ("username".equals(element.getName())) {
String username = element.getText();
c.setUserName(username);
}
if ("password".equals(element.getName())) {
String password = element.getText();
c.setPassword(password);
}
}
persons.add(c);
}
return persons;
} /*
* 根据person的属性id查询xml
* */
public static ClientLoginUser QueryClinetLoginUserById(String appDir,int id) throws Exception{
File dir = new File(appDir+"\\persons.xml");
String dirPath = dir+"";
Document dom = UtilsForXML.getDocument(dirPath);
Element root = dom.getRootElement();
ClientLoginUser person = new ClientLoginUser();
Element beQuery = (Element)root.selectSingleNode("//person[@id="+id+"]");
if(beQuery!=null){
person.setPublisherName(beQuery.elementText("publishername"));
person.setServerUrl(beQuery.elementText("serverurl"));
person.setUserName(beQuery.elementText("username"));
person.setPassword(beQuery.elementText("password"));
person.setId(id);
}
return person;
}
/*
* 增加xml数据
* */
public static int AddClinetLoginUser(String appDir,String publisherName,String serverUrl,String userName,String passWord) throws Exception{
File dir = new File(appDir+"\\persons.xml");
if (!dir.exists()) {
dir.createNewFile();
}
int id = 1;
String dirPath = dir+"";
Document dom = UtilsForXML.getDocument(dirPath);
Element root = dom.getRootElement();
List<Element> list = root.elements("person");
if(!list.isEmpty()||list.size()!=0){
int count = list.size();
Element lastperson = list.get(count-1);
String value = lastperson.attributeValue("id");
id = Integer.parseInt(value)+1;
}
// int id = (int) ((Math.random()*9+1)*1000);
Element newPerson = root.addElement("person");
newPerson.addAttribute("id", id+"");
Element publishername = newPerson.addElement("publishername");
publishername.setText(publisherName);
Element serverurl = newPerson.addElement("serverurl");
serverurl.setText(serverUrl);
Element username = newPerson.addElement("username");
username.setText(userName);
Element password = newPerson.addElement("password");
password.setText(passWord);
UtilsForXML.writeToXML(dom, dirPath);
return id;
} /*
* 根据person属性id修改xml数据
* */
public static int UpdateClinetLoginUser(int id,String appDir,String publisherName,String serverUrl,String userName,String passWord) throws Exception{
File dir = new File(appDir+"\\persons.xml");
String dirPath = dir+"";
Document dom = UtilsForXML.getDocument(dirPath);
Element root = dom.getRootElement();
Element beQuery = (Element)root.selectSingleNode("//person[@id="+id+"]");
beQuery.element("publishername").setText(publisherName);
beQuery.element("serverurl").setText(serverUrl);
beQuery.element("username").setText(userName);
beQuery.element("password").setText(passWord);
UtilsForXML.writeToXML(dom, dirPath);
return id;
}
/*
* 根据person属性id删除xml数据
* */
public static int DeleteClinetLoginUser(int id,String appDir) throws Exception{
File dir = new File(appDir+"\\persons.xml");
String dirPath = dir+"";
Document dom = UtilsForXML.getDocument(dirPath);
Element root = dom.getRootElement();
Element beQuery = (Element)root.selectSingleNode("//person[@id="+id+"]");
beQuery.getParent().remove(beQuery);
UtilsForXML.writeToXML(dom, dirPath);
return id;
}
}
需要的工具类:
package com.founder.mrp.util; import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.InputStreamReader;
import java.io.OutputStream;
import java.io.OutputStreamWriter;
import java.io.Reader; import org.dom4j.Document;
import org.dom4j.io.OutputFormat;
import org.dom4j.io.SAXReader;
import org.dom4j.io.XMLWriter; public class UtilsForXML {
/**
* 需要一个方法来创建DOM4j的XML解析器并返回一个document对象
* add by hanwl
* @throws Exception
*/
public static Document getDocument(String xmlPath) throws Exception {
Reader reader = new InputStreamReader(new FileInputStream(new File(xmlPath)),"utf-8");
SAXReader saxReader = new SAXReader();
//将XML文件路径传给Document对象并返回其实例dom
Document dom = saxReader.read(reader);
return dom;
} /**
* 需要一个方法来将更新后的document对象写入到XML文件中去
* add by hanwl
* @throws Exception
*/
public static void writeToXML(Document dom ,String xmlPath) throws Exception{ //首先创建样式和输出流
OutputFormat format = new OutputFormat().createPrettyPrint();
OutputStreamWriter out = new OutputStreamWriter(new FileOutputStream(xmlPath),"utf-8");
//OutputStream out = new FileOutputStream(xmlPath);
XMLWriter writer = new XMLWriter(out,format); //写入之后关闭流
writer.write(dom);
writer.close();
}
}
用到的实体类:
package com.founder.mrp.domain;
public class ClientLoginUser {
private int id;
private String publisherName;
private String serverUrl;
private String userName;
private String password;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getPublisherName() {
return publisherName;
}
public void setPublisherName(String publisherName) {
this.publisherName = publisherName;
}
public String getServerUrl() {
return serverUrl;
}
public void setServerUrl(String serverUrl) {
this.serverUrl = serverUrl;
}
public String getUserName() {
return userName;
}
public void setUserName(String userName) {
this.userName = userName;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
}
这是web程序操作的代码,一些controller请求和jsp页面没有放,主要看dom4j操作xml
下面是本次用例XML文件:
<?xml version="1.0" encoding="UTF-8"?>
<persons>
<person id="1">
<publishername>测试3</publishername>
<serverurl>http://loalhost</serverurl>
<username>test3</username>
<password>123456</password>
</person>
<person id="2">
<publishername>测试4</publishername>
<serverurl>http://localhost</serverurl>
<username>test4</username>
<password>123456</password>
</person>
</persons>
Java使用DOM4J对XML文件进行增删改查操作的更多相关文章
- 使用dom4j对xml文件进行增删改查
1.使用dom4j技术对dom_demo.xml进行增删改查 首选要下载dom4j的jar包 在官网上找不到,网上搜索了一下在这个链接:http://sourceforge.net/projects/ ...
- java对xml文件做增删改查------摘录
java对xml文件做增删改查 package com.wss; import java.io.File;import java.util.ArrayList;import java.util.Lis ...
- Asp.Net 操作XML文件的增删改查 利用GridView
不废话,直接上如何利用Asp.NET操作XML文件,并对其属性进行修改,刚开始的时候,是打算使用JS来控制生成XML文件的,但是最后却是无法创建文件,读取文件则没有使用了 index.aspx 文件 ...
- php对xml文件的增删改查
源文件<?xml version="1.0" encoding="utf-8"?><root> <endTime>2016 ...
- C# 本地xml文件进行增删改查
项目添加XML文件:FaceXml.xml,并复制到输出目录 FaceXml.xml <?xml version="1.0" encoding="utf-8&quo ...
- java对xml文件做增删改查
http://www.cnblogs.com/wangchenyang/archive/2011/08/23/2150530.html http://www.blogjava.net/weishuan ...
- dom4j解析xml文档(增删改查)
package itcast.dom4j; import java.io.File; import java.io.FileOutputStream; import java.io.FileWrite ...
- xml 文件的增删改查
序列化和反序列化helper using System; using System.Collections.Generic; using System.Linq; using System.Text; ...
- SpringBoot结合Mybatis 使用 mapper*.xml 进行数据库增删改查操作
什么是 MyBatis? MyBatis 是支持普通 SQL 查询,存储过程和高级映射的优秀持久层框架. MyBatis 消除了几乎所有的 JDBC 代码和参数的手工设置以及对结果集的检索. MyBa ...
随机推荐
- OV摄像头图像采集基础知识总结
目前FPGA用于图像采集 传输 处理 显示应用越来越多,主要原因是图像处理领域的火热以及FPGA强大的并行处理能力.本文以OV7725为例,对摄像头使用方面的基础知识做个小的总结,为后续做个铺垫. 下 ...
- oracle nvl2函数
nvl2(v1, v2, v3) 定义:如果v1为空,返回v3: 不为空,返回v2 nvl2要求v2,v3的类型一致,不一致会发生类型转换.问题:最终返回值类型是v2的类型还是v3的类型? 看题目:n ...
- VMware虚拟机上网络连接解决方案
VMware虚拟机上网络连接解决方案 作者:凯鲁嘎吉 - 博客园http://www.cnblogs.com/kailugaji/ 从虚拟机上连接外部网络,需要设置以下几个地方. 1.服务 (1)打开 ...
- LinuxMint上安装redis和python遇到的一些问题
今天在安装Redis和Python上遇到了些问题,解决后记录下来. 环境:LinuxMint 18.3 安装redis sudo wget http://download.redis.io/relea ...
- 【技术文章】《快速上手nodejs》
本文地址:http://www.cnblogs.com/aiweixiao/p/8294814.html 原文地址: 扫码关注微信公众号 1.写在前面 nodejs快速上手 nodejs使ja ...
- abstract关键字 super 关键字 类与继承
https://www.cnblogs.com/liubing2018/p/8421319.html https://www.cnblogs.com/dolphin0520/p/3803432.htm ...
- requests的基本用法
r = requests.get('https://api.github.com/events', params = {'key1': 'value1', 'key2': 'value2'}) r = ...
- 爬虫系列二(数据清洗--->bs4解析数据)
一 BeautifulSoup解析 1 环境安装 - 需要将pip源设置为国内源,阿里源.豆瓣源.网易源等 - windows (1)打开文件资源管理器(文件夹地址栏中) (2)地址栏上面输入 %ap ...
- nuxt axios代理
modules: [ '@nuxtjs/axios', ], axios: { //prefix: '/api/', proxy: true // Can be also an object with ...
- 总结JAVA----IO流中的File类
对于IO流中File类的总结 File类的基本概念 File类只能用于完成对于文件属性(是否存在.可读性.长度)的一些操作,不能用于文件的访问. File类的对象 File类的对象存储的是文件的绝对路 ...