使用Digester的感受
来源:互联网 发布:qq动态图片软件 编辑:程序博客网 时间:2024/05/21 22:51
使用Digester的感受
1.先导入jar包到工程中,至少有4个
commons-logging-1.1.1.jar
commons-beanutils.jar
commons-collections-3.2.jar
commons-digester-1.8.jar
2.根据XML文件建立所有的JavaBean对象
3.在程序中
A:新建Digester对象
Digester digester = new Digester();
B: 设置不检查XML文档合法性
digester.setValidating(false);
C:如果碰到某个元素,添加并创建这个对应的类,个人理解,应该把全部的类都加载进来,第一个参数是元素名,第二个参数是该类的全限定名。
digester.addObjectCreate("KPI_DEFINE", bean.Kpi_Define.class);
D:加载类后,如果碰到某个元素有属性的话,添加这个类的属性,第一个参数为碰到的元素,第二个参数为XML文档中的属性名,第三个参数为对应类中的属性名
digester.addSetProperties("KPI_DEFINE/UNIT_KPI_DETAIL/UNIT_KPI","ID","id");
F:如果再次碰到某个元素,就执行上级元素的某个方法,添加当前元素,第一个参数是这个元素,第二个参数是调用上一个元素(类)中的方法名
digester.addSetNext("KPI_DEFINE/UNIT_KPI_DETAIL/UNIT_KPI/DIM_INFO", "setDim_info");
注意事项:根据XML文档元素,一级一级的来,不要跳级
G:添加结束后,准备解析,先创建一个根元素的类对象,调用digester.parse("参数")方法,参数可以选2种中的一种。这个方法可以得到XML文档的根元素(对象)
Kpi_Define kd;
kd = (Kpi_Define) digester.parse(new File("C://basicKpiDefine.xml"));//文件方式,把XML文件发在C盘根目录下
kd = (Kpi_Define) digester.parse(this.getClass().getClassLoader().getResourceAsStream("basicKpiDefine.xml"));//IO流方式
4.基本能解析了
下面说说rule方式,就是通过一个rule.xml文件定义解析的模板,这样不需要加载那么多的元素了(适用于元素超多的复杂的情况)
1.同理导入jar
2.根据XML文件建立javabean
3.在程序中
A:需要新建一个rule.xml文件(名字随意)
B:最主要的就是用什么样的格式写出rule.xml,有几个特定标签需要大家熟悉一下
<digester-rules>:根标记,不可缺少
<pattern value="XXXXX">:元素,XXX是XML文档中的元素名,一模一样的,参数不用写元素的路径(即不需要写成"UNIT_KPI_DEFINE/UNIT_KPI"这个样子,直接写"UNIT_KPI"就可以)
<object-create-rule classname="写入类的全限定名" />:碰到上面那个标记,就创建这个对象,参数为类的全限定名,包名+类名
<set-next-rule methodname="setXXX或者addXXX方法" />:下次碰到这个元素调用的方法(当然这次也调用了参数中的方法),用于多个重复元素
<set-properties-rule>:这个元素是设置属性的标签(属性在标签内部定义的那种,例如:<student id="1" name="gl" />)两种用法:
第一种情况:如果类中的属性和标签中的属性大小写相同,可以这么用:
<set-properties-rule>
<alias attr-name="*" prop-name="*" />
<set-properties-rule>
第二种情况:如果类中的属性和标签的属性大小写不同的话,只能这么用:
<set-properties-rule>
<alias attr-name="ID" prop-name="id" />
<alias attr-name="NAME" prop-name="name" />
</set-properties-rule>
挨个赋值
------------------------------------------------------
还有几个标签,暂时没弄明白怎么回事,如果知道的,可以告诉我
<bean-property-setter-rule pattern="" propertyname=""/> :貌似是设置bean属性的,调用setter方法,但是我没用成功
<call-method-rule>:貌似是调用setter方法的,需要和下一个标签配合使用
<call-param-rule>:调用setter方法是需要传入的参数。
暂时这么理解的,如果又错误的请通知我一下,也好给大家弄个明白。
4.基本就可以写完rule.xml文档了,最后,我们载入这个规则,和载入要解析的XML文件
digester = DigesterLoader.createDigester(new File("c://rule.xml").toURL());//载入规则rule.xml文件,需要放在C盘根目录下,没找到更好的办法
this.kpi_define = (Kpi_Define) digester.parse(this.getClass().getClassLoader().getResourceAsStream("basicKpiDefine.xml")); //加载需要解析的XML文件,获得根元素
-----------------------------------------
在项目中:
1.一般读大的XML文件很慢,如果不经常改动的XML文件,可以使用单例模式,只读取一遍XML文档,重复使用,如果经常改变XML文档的话,那么就另写一个读新XML文档的方法(其实实现是一样的),效率会提高很多
2.不一定需要把所有元素都做成对象
3.如果用myEclipse写rule.xml文档的话,可以把dtd文件,导入到myeclipse中,在新建XML文档时候,选择DTD模板,在写rule.xml的时候就会有自动提示,非常方便和效率!具体导入如下
1.下载DTD文件,到本地
2.打开myeclipse(6.6为例,其他也一样),依次window->preferences->myeclipse enterprise workbench ->files and editors -> XML ->XML Catalog ->点击ADD按钮 ->选择catalog entry -> 在Location处选择 file system ,找到DTD文件 确定 -> 在key type中选择URI -> 在key中 把下载这个DTD的地址写上 -> ok 搞定
3.回到开发状态,新建XML文档的时候,选择 XML(basic Templates)->随便写个名字 点击next -> 选择create xml file from a DTD file 点击 next ->选择 select XML Catalog entry -> 找到你刚才定义的DTD文件,next-> 这个对话框是定义元素选项的,一般不用动(除非又特殊需求) -> finish完成即可
- 使用Digester的感受
- Digester的使用
- digester使用
- Tomcat中使用的组件-Digester组件
- Digester中正则表达式的使用
- Java XML解析之Digester的使用
- Java XML解析之Digester的使用
- Delphi2005的使用感受
- googlepages的使用感受
- 使用xtree的感受
- 使用fastdb的感受
- P1000的使用感受
- 使用fastdb的感受
- UIButton 使用的感受
- DButils的使用感受
- Git的使用感受
- Jeecg的使用感受
- bootstrap2 的使用感受
- 在C#语言中,重载和重写的区别到底在什么地方?
- 检查SAP系统中货币是否存在
- ruby对model进行验证的几个问题
- AppKit 应用程序设计观(转)
- tomcat 启动的问题(org.apache.catalina.session.StandardManager.doLoad: IOException while loading persisted sessions)
- 使用Digester的感受
- [转]vc中socket编程步骤
- Oracle查询简单数据字典SQL语句
- RFC 3261中示例分析——会话部分
- DB2中导出数据库的所有DLL脚本
- 安装TestDriven.net 遇到不能访问Windows Installer服务的问题,解决!!!
- request.getAttribute()和request.getParameter()区别[转载]
- C++学习比较经典的书籍
- 一个有意思的问题(关于SendMessage)