styxmx 发表于 2018-1-9 09:40:20

解析xml文件,修改Jenkins的配置

package other;  

  
import java.io.File;
  
import java.io.FileWriter;
  
import java.io.IOException;
  
import java.net.URL;
  
import java.util.ArrayList;
  
import java.util.Iterator;
  
import java.util.List;
  

  
import org.dom4j.Attribute;
  
import org.dom4j.Document;
  
import org.dom4j.DocumentException;
  
import org.dom4j.Element;
  
import org.dom4j.io.SAXReader;
  
import org.dom4j.io.XMLWriter;
  

  
import bsh.This;
  
import until.publicmethod;
  


  
public>  static String path;//获取的路径
  static Document document;
  static StringjointURl;
  /**
  *
  * @测试点: 遍历指定目录,获取文件路径
  @param @param filePath
  @param @return
  * @备注: List<String>
  * @author zhangjun
  * @date 2017年9月18日
  @修改说明
  */
  public static List<String> geturl(String filePath) {
  List<String> list = new ArrayList<String>();
  File root = new File(filePath);
  File[] files = root.listFiles();
  for (File file : files) {
  if (file.isDirectory()) {
  list.add(file.getAbsolutePath());
  //System.out.println("显示" + filePath + "下所有子目录及其文件" + file.getAbsolutePath());
  }
  }
  return list;
  }
  

  
/**
  *
  
* @测试点: 读取Jenkins的xml文件,修改指定的节点
  
* @验证点: TODO(这里用一句话描述这个方法的作用)
  
*   @param @param url   需要传入的修改的xml文件路径
  
* @备注: void
  
* @author zhangjun
  
* @date 2017年9月18日
  @修改说明
  */
  public static void readerXml(String url) {
  SAXReader reader = new SAXReader();
  System.out.println("获取的url:"+jointURl);
  try {
  document = reader.read(new File(url));
  // 通过reader对象的read方法加载books.xml文件,获取docuemnt对象。
  Element bookStore = document.getRootElement();
  // 通过element对象的elementIterator方法获取迭代器
  Iterator it = bookStore.elementIterator();
  // 遍历迭代器,获取根节点中的信息(书籍)
  while (it.hasNext()) {
  // System.out.println("=====开始遍历=====");
  Element jenkinsjob = (Element) it.next();
  // 获取book的属性名以及 属性值
  

  // 解析子节点的信息,这个下面是否可以做优化,目前没有好的方案
  Iteratorjobs= jenkinsjob.elementIterator();
  while (jobs.hasNext()) {
  Element Child = (Element) jobs.next();
  /*System.out.println("节点名:" + Child.getName() + "--节点值:" + Child.getStringValue());*/
  if (Child.getName().equals("hudson.plugins.sidebar__link.ProjectLinks")) {
  Iterator node = Child.elementIterator();
  while (node.hasNext()) {
  Element Child2 = (Element) node.next();
  System.out.println("节点名2:" + Child2.getName() + "--节点值2:" + Child2.getStringValue());
  

  Iterator node2 = Child2.elementIterator();
  while (node2.hasNext()) {
  Element Child3= (Element) node2.next();
  System.out.println(
  "节点名3:" + Child3.getName() + "--节点值3:" + Child3.getStringValue());
  

  Iterator node3 = Child3.elementIterator();
  while (node3.hasNext()) {
  Element Child4 = (Element) node3.next();
  System.out.println(
  "节点名4:" + Child4.getName() + "--节点值4:" + Child4.getStringValue());
  if (Child4.getName().equals("url")) {
  Child4.setText("http://192.168.11.11:8080/jenkins/job/new_rosewholesale_conventionpay/");
  }
  break;
  }
  }
  

  }
  }
  

  }
  }
  

  } catch (DocumentException e) {
  e.printStackTrace();
  System.out.println("读取文件错误");
  }
  /**
  * 写入文件,重新生成xml文件
  */
  try {
  XMLWriter writer = new XMLWriter(new FileWriter(url));
  writer.write(document);
  writer.close();
  } catch (IOException e) {
  e.printStackTrace();
  System.out.println("写入文件错误");
  }
  }
  //DOM4J 方式解析XML
  public static void main(String[] args) {
  List<String> filespath=geturl("D:\\test\\test2\\");
  for(int i=0;i<filespath.size();i++){
  Stringfilepath=filespath.get(i);
  readerXml(filepath+"\\config.xml");
  }
  }
  

  
}
  
页: [1]
查看完整版本: 解析xml文件,修改Jenkins的配置