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:应用集成平台主要作为企业信息系统的“龙骨”来集成各业务系统,一般称之为企业服务总线(EnterpriseServiceBUS,ESB),在数通畅联软件的产品家族中应用集成平台命名为AEAIESB
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”); contentElm.addCDATA(“cdata区域”);
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 it=root.attributeIterator();it.hasNext();){
Attribute attribute = (Attribute) it.next();
//操作处理
}
3.4 XML和字符串转换
拼好XML格式数据后,需要调用接口,而接口的入参类型为String,这里需要将拼好的Document对象转换为字符串,方式为
String docText=document.asXML();
而将XML格式的字符串转换为document对象的方式为
String text = “XML格式数据”;
Document document = DocumentHelper.parseText(text);
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 XMLWriter(newFileWriter(“contentChinese.xml”),format);
writer.write(document);
writer.close();
5 实例代码
流程服务涉及到的部分相关代码
创建document对象并拼接XML
DataRow headerDataRow = (DataRow) this.getVariable(“headerDataRow”).getValue();
// XmlUtil是一个XML操作工具类,在数通畅联产品内置的jar包中
Document document = XmlUtil.createDocument();
Element dataElement = document.addElement(“DATA”);
dataElement.addElement(“REQUESTDATA”);
Element datainfosElement = dataElement.addElement(“DATAINFOS”);
datainfosElement.addAttribute(“REMARK”, “主表”);
Element danhaoElement = datainfosElement.addElement(“DANHAO”);
danhaoElement.addAttribute(“REMARK”, “单号”);
danhaoElement.addText(headerDataRow.getString(“APPLY_NUMBER”));
Element xingmingElement = datainfosElement.addElement(“XINGMING”);
xingmingElement.addAttribute(“REMARK”, “姓名”);
xingmingElement.addText(headerDataRow.getString(“APPLY_USER_NAME”));
解析接口返回的XML格式数据,并判断ESB_CODE节点的内容
//getVariable是ESB中封装好的方法,用于通过CODE值获取流程变量
String soapResponse = (String) this.getVariable(“soapResponse”).getValue();
Document document = DocumentHelper.parseText(soapResponse);
Element root = document.getRootElement();
Element resultCode = root.element(“ESB_CODE”);
int resultMark = 0;
if(“S”.equals(resultCode.getText())){
resultMark = 1;
int applyId = (Integer) this.getVariable(“applyId”).getValue();
DataRow updateRow = new DataRow(“APPLY_ID”,applyId,”OA_FLAG”,”N”);
this.getVariable(“updateRow”).setValue(updateRow);
}
注:附件为操作样例工程代码,解析Project.xml文件并对其进行增删改查操作 文档及附件下载
如果困难是堵砖墙,拍拍它说你还不够高。