一、业务需求
Java代码解析XML文件,将数据返回页面以下拉框的形式展现
二、代码实现
1、XML文件
<?xml version="1.0" encoding="UTF-8"?>
<root>
<fieldType>
<type value = "1" >字符串</type>
<type value = "2" >数字</type>
<type value = "3" >日期</type>
<type value = "4" >布尔型</type>
</fieldType>
<inputType>
<type value = "1" >单选框</type>
<type value = "2" >复选框</type>
<type value = "3" >下拉框</type>
<type value = "4" >文本框</type>
<type value = "5" >文本域</type>
</inputType>
</root>
2、JAVA代码实现
1)、创建一个JavaBean 用来封装XML里面的键值对数据
public class XmlBean{
private Integer value ;
private String name;
public Integer getValue() {
return value;
}
public void setValue(Integer value) {
this.value = value;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
2)、在Controller里面进行解析,并将结果返回给页面
@RequestMapping("testXml")
public String testXml(HttpServletRequest request,HttpServletResponse response,HttpSession session) {
<span style="white-space:pre"> </span>SAXReader reader = new SAXReader();
Document document;
//List用来存储XML中的值
List<XmlBean> fieldTypes = new ArrayList<XmlBean>();
List<XmlBean> inputTypes = new ArrayList<XmlBean>();
try {
//获取文件路径
String url = session.getServletContext().getRealPath("/") + "static\\xml\\dropDownList.xml";
System.out.println(url);
//读入XML文件
document = reader.read(new File(url));
//获取根节点
Element root = document.getRootElement();
//获取根节点下的fieldType节点
Element fieldTypeNode = root.element("fieldType");
System.out.println(fieldTypeNode.getName());
//获取fieldType节点下的所有type节点
List<?> fields = fieldTypeNode.elements("type");
System.out.println(fields.size());
//遍历所有的type节点
for(Iterator<?> it = fields.iterator();it.hasNext();){
Element item = (Element)it.next();
//获取节点的属性值
Integer value = Integer.parseInt(item.attributeValue("value"));
//获取节点内容
String name = item.getText();
//xml数据对应的实体类
XmlBean xmlBean = new XmlBean();
xmlBean.setValue(value);
xmlBean.setName(name);
fieldTypes.add(xmlBean);
}
request.setAttribute("fieldTypes", fieldTypes);
Element inputTypeNode = document.getRootElement().element("inputType");
List<?> inputs = inputTypeNode.elements("type");
for(Iterator<?> it = inputs.iterator();it.hasNext();){
Element item = (Element)it.next();
Integer value = Integer.parseInt(item.attributeValue("value"));
String name = item.getText();
//xml数据对应的实体类
XmlBean xmlBean = new XmlBean();
xmlBean.setValue(value);
xmlBean.setName(name);
inputTypes.add(xmlBean);
}
request.setAttribute("inputTypes", inputTypes);
} catch (DocumentException e) {
e.printStackTrace();
}
return "skuProperty/testXmlList";
}
3、JSP页面
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<section class="content-header">
<h1>
解析XML文件 <small>解析XML文件</small>
</h1>
<ol class="breadcrumb">
<li><a href="#"><i class="fa fa-dashboard"></i> home</a></li>
<li class="active">Here</li>
</ol>
</section>
<!-- Main content -->
<section id="" class="content">
<div class="row">
<div class="col-md-9">
<div class="box box-primary">
<div class="box-header">
<h3 class="box-title">XML文件解析</h3>
</div>
<!-- /.box-header -->
<!-- form start -->
<div class = "box-body">
<select name = "xmlTest" id = "xmlTest" >
<c:forEach items = "${fieldTypes }" var = "type">
<option value = "${ type.value}">${type.name}</option>
</c:forEach>
</select>
</div>
</div>
</div>
</div>
</section>
A、javaBean 的属性选择要根据实际业务需求来定,此Demo目的是返回一个下拉表形式的数据,所以此处JavaBean XmlBean只有两个属性,value,name
B 、解析XML文件的过程可以封装成一个Util工具类,便于代码的复用,解析函数用的是dom4解析技术,所以要实现此功能,要导入dom4j的jar包,我用的是dom4j-1.6.1.jar,
下载此jar包地址:http://download.youkuaiyun.com/detail/andyo_o/8934649
C、此Demo是基于SpringMVC 框架来实现的