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文件进行增删改查操作的更多相关文章

  1. 使用dom4j对xml文件进行增删改查

    1.使用dom4j技术对dom_demo.xml进行增删改查 首选要下载dom4j的jar包 在官网上找不到,网上搜索了一下在这个链接:http://sourceforge.net/projects/ ...

  2. java对xml文件做增删改查------摘录

    java对xml文件做增删改查 package com.wss; import java.io.File;import java.util.ArrayList;import java.util.Lis ...

  3. Asp.Net 操作XML文件的增删改查 利用GridView

    不废话,直接上如何利用Asp.NET操作XML文件,并对其属性进行修改,刚开始的时候,是打算使用JS来控制生成XML文件的,但是最后却是无法创建文件,读取文件则没有使用了 index.aspx 文件 ...

  4. php对xml文件的增删改查

    源文件<?xml version="1.0" encoding="utf-8"?><root>  <endTime>2016 ...

  5. C# 本地xml文件进行增删改查

    项目添加XML文件:FaceXml.xml,并复制到输出目录 FaceXml.xml <?xml version="1.0" encoding="utf-8&quo ...

  6. java对xml文件做增删改查

    http://www.cnblogs.com/wangchenyang/archive/2011/08/23/2150530.html http://www.blogjava.net/weishuan ...

  7. dom4j解析xml文档(增删改查)

    package itcast.dom4j; import java.io.File; import java.io.FileOutputStream; import java.io.FileWrite ...

  8. xml 文件的增删改查

    序列化和反序列化helper using System; using System.Collections.Generic; using System.Linq; using System.Text; ...

  9. SpringBoot结合Mybatis 使用 mapper*.xml 进行数据库增删改查操作

    什么是 MyBatis? MyBatis 是支持普通 SQL 查询,存储过程和高级映射的优秀持久层框架. MyBatis 消除了几乎所有的 JDBC 代码和参数的手工设置以及对结果集的检索. MyBa ...

随机推荐

  1. Ubuntu17.04 sudo apt-get update升级错误

    最近在折腾Ubuntu,安装的是17.04版本的.想安装PHP7.X最新版本,但是要先升级.利用sudo apt-get update命名后,出现了以下报错: 忽略:1 http://cn.archi ...

  2. 用 PLSQL 创建新用户及导入 dmp

    一.创建表空间 在导入 dmp 文件之前,你要在数据库里面给它分配一片存储它的地方(表空间). 如果我们知道需要导入的数据库的表空间直接创建就可以,如果不不知道,也没有关系,我们可以用 txt 打开 ...

  3. Python 函数初识 (1)

    一.今日主要内容 认识函数 函数:对功能或者动作的封装(定义) 语法: def 函数名字(形参) 函数体 函数的调用格式:函数名(实参) 函数的返回值 关键字:return 终止函数的运行 1.函数内 ...

  4. mn

    http://image.uczzd.cn/10129986679866437816.jpg?id=0&from=export https://www.cnblogs.com/ityoukno ...

  5. Spark-RDD之Partition源码分析

    概要 Spark RDD主要由Dependency.Partition.Partitioner组成,Partition是其中之一.一份待处理的原始数据会被按照相应的逻辑(例如jdbc和hdfs的spl ...

  6. CSAPP:第八章 异常控制流2

    CSAPP:第八章 异常控制流2 关键点:进程控制.信号 8.4 进程控制8.5 信号 8.4 进程控制   Unix提供了大量从C程序中操作进程的系统调用.8.4.1 获取进程ID  每个进程都有一 ...

  7. parquet文件 读取 原理

    学习一下parquet存储结构 原理 以及使用

  8. node+mysql 数据库连接池

    1. 什么是数据库连接池? 数据库连接池是程序启动时建立足够的数据库连接,并将这些连接组成一个池,由程序动态地对池中的连接进行申请,使用和释放. 2. 使用数据库连接池原理及优点是什么? 数据库连接池 ...

  9. MyBatis 学习总结 01 快速入门

    本文测试源码下载地址: http://onl5wa4sd.bkt.clouddn.com/MyBatis0918.rar 一.Mybatis介绍 MyBatis是一个支持普通SQL查询,存储过程和高级 ...

  10. Django rest framework(6)----序列化(2)

    为什么要序列化 django 查询数据库返回的类型是  queryset 类型 而我们和前端通信使用的大多数是json类型,这个时候我们需要把 queryset的数据类型转换成python的数据类型然 ...