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 class xmlDom { static String path; //获取的路径 static Document document; static String jointURl; /** * * @测试点: 遍历指定目录,获取文件路径 @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的属性名以及 属性值 // 解析子节点的信息,这个下面是否可以做优化,目前没有好的方案 Iterator jobs= 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++){ String filepath=filespath.get(i); readerXml(filepath+ "\\config.xml" ); } } } |
所有评论(0)