1 概述
在进行ESB集成项目中,使用到了很多系统的接口,这些接口传输的数据大部分都采用了XML的格式,这样在使用ESB开发服务时就需要对XML数据进行解析或拼接的操作,本文以项目中流程服务为例,讲解一些常用的Dom4j对XML的操作。
2 名词解释
Dom4j:一个Java的XML API,用来读写XML文件的,具有性能优异、功能强大和极端易用使用的特点。
使用Dom4j需要使用对应的jar包,官网下载地址:
http://www.dom4j.org/dom4j-1.6.1/
Dom4jAPI地址:
http://www.oschina.net/uploads/doc/dom4j-1.6.1/index.html
AEAI ESB:应用集成平台主要作为企业信息系统的“龙骨”来集成各业务系统,一般称之为企业服务总线(Enterprise Service BUS,ESB),在数通畅联软件的产品家族中应用集成平台命名为AEAI ESB
3 操作方法
在ESB流程中需要先查询出第三方系统需要的数据,再进行XML格式化处理后,调用第三方系统提供的Web Service服务,这里需要创建一个XML格式的数据。
3.1 创建Document对象
这里采用以下方法主动创建document对象
Document document = DocumentHelper.createDocument(); |
查询相关API发现还有另外两种创建对象的方法
1.读取XML文件,获得document对象
SAXReader reader = new SAXReader(); Document document = reader.read(new File("csdn.xml")); |
2.解析XML形式的文本,得到document对象
String text = "XXXX"; Document document = DocumentHelper.parseText(text); |
3.2 节点操作
创建document后,添加第一个节点
Element dataElement = document.addElement("DATA"); |
这个节点作为根节点
这里通过API来说明一下其他节点操作的方法
1.获取根节点
Element root = document.getRootElement();
2.取得某个节点的子节点.
Element element= root.element(“REQUESTDATA”);
3.取得节点的内容
String text= element.getText();
4.取得某节点下所有名为” REQUESTDATA”的子节点,并进行遍历
List elements = rootElm.elements("csdn"); for (Iterator it = elements.iterator(); it.hasNext();) { Element elm = (Element) it.next(); //操作处理 } |
5.对某节点下的所有子节点进行遍历
for(Iterator it=root.elementIterator();it.hasNext();){ Element element = (Element) it.next(); //操作处理 } |
6.设置节点文字
element.setText("XXXX"); |
7.删除某节点
childElement是待删除的节点 parentElement是其父节点 parentElement.remove(childElment); |
8.添加一个CDATA节点
在拼接完整的soap请求体时,涉及到soap请求体中添加XML格式数据时,不需要soap协议进行解析的内容,需要添加CDATA节点
Element contentElm = infoElm.addElement("content"); |
3.3 属性操作
添加了节点后,需要在节点中进行说明此节点的含义,这时需要给这个节点添加属性
element.addAttribute("属性名 ", "内容"); |
通过相关API找到其他的属性操作方法
1.取得某节点下的某属性
Element root=document.getRootElement(); Attribute attribute=root.attribute("属性名"); |
2.取得属性的内容
String text=attribute.getText(); |
3.删除某属性
Attribute attribute=root.attribute("属性名"); root.remove(attribute); |
4.设置属性的内容
Attribute attribute=root.attribute("属性名"); attribute.setText("内容"); |
5.遍历某节点的所有属性
Element root=document.getRootElement(); for(Iterator Attribute attribute = (Attribute) //操作处理 } |
3.4 XML和字符串转换
拼好XML格式数据后,需要调用接口,而接口的入参类型为String,这里需要将拼好的Document对象转换为字符串,方式为
String docText=document.asXML(); |
而将XML格式的字符串转换为document对象的方式为
String text = "XML格式数据"; Document document = |
4 其他说明
4.1 文档操作
1.全为英文
XMLWriter writer = new XMLWriter(new FileWriter("allEnglish.xml")); writer.write(document); writer.close(); |
2.含有中文
OutputFormat format = OutputFormat.createPrettyPrint(); // 创建文件输出的时候,自动缩进的格式 format.setEncoding("UTF-8"); //设置编码 XMLWriter writer = new writer.write(document); writer.close(); |
5 实例代码
流程服务涉及到的部分相关代码
创建document对象并拼接XML
DataRow // Document document = Element dataElement = dataElement.addElement("REQUESTDATA"); Element datainfosElement datainfosElement.addAttribute("REMARK", Element danhaoElement = danhaoElement.addAttribute("REMARK", danhaoElement.addText(headerDataRow.getString("APPLY_NUMBER")); Element xingmingElement = xingmingElement.addAttribute("REMARK", xingmingElement.addText(headerDataRow.getString("APPLY_USER_NAME")); |
解析接口返回的XML格式数据,并判断ESB_CODE节点的内容
//getVariable是ESB中封装好的方法,用于通过CODE值获取流程变量 String Document document = Element root = Element resultCode = int resultMark = 0; if("S".equals(resultCode.getText())){ resultMark = 1; int applyId = DataRow updateRow this.getVariable("updateRow").setValue(updateRow); } |
注:附件为操作样例工程代码,解析Project.xml文件并对其进行增删改查操作 文档及附件下载