在上篇中写的只支持写属性,不支持标签property的写法,但是如果有时候我们还想做成支持 property的用法,则可以在xsd中增加spring 自带的xsd引用
修改xsd文件如下:
<?xml version="1.0"encoding="UTF-8"?> <xsd:schema xmlns="http://www.ruishenh.com/custom/myTest" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:beans="http://www.springframework.org/schema/beans" targetNamespace="http://www.ruishenh.com/custom/mytest" elementFormDefault="qualified" attributeFormDefault="unqualified"> <xsd:import namespace="http://www.springframework.org/schema/beans"/> <xsd:element name="executor"> <xsd:complexType> <xsd:complexContent> <xsd:extension base="beans:identifiedType"> <xsd:group ref="beans:beanElements" /> <xsd:attribute name="name" type="xsd:string"/> <xsd:attribute name="delay" type="xsd:int"/> <xsd:attribute name="interval" type="xsd:int"/> <xsd:attribute name="address" type="xsd:string"/> <xsd:attribute name="entity" type="xsd:string"/> </xsd:extension> </xsd:complexContent> </xsd:complexType> </xsd:element> <xsd:element name="entity"> <xsd:complexType> <xsd:complexContent> <xsd:extension base="beans:identifiedType"> <xsd:group ref="beans:beanElements" /> <xsd:attribute name="name" type="xsd:string"/> <xsd:attribute name="splitBy" type="xsd:string"/> <xsd:attribute name="sql" type="xsd:string"/> <xsd:attribute name="dbTypeID"> <xsd:simpleType> <xsd:restriction base="xsd:int"> <xsd:enumeration value="1" /> <xsd:enumeration value="2" /> <xsd:enumeration value="3" /> </xsd:restriction> </xsd:simpleType> </xsd:attribute> <xsd:attribute name="dbTypeName"> <xsd:simpleType> <xsd:restriction base="xsd:string"> <xsd:enumeration value="mysql" /> <xsd:enumeration value="oracle" /> <xsd:enumeration value="sqlserver" /> </xsd:restriction> </xsd:simpleType> </xsd:attribute> </xsd:extension> </xsd:complexContent> </xsd:complexType> </xsd:element> </xsd:schema>
修改BeanDefinitionPaser如下
package com.ruishenh.spring.config; import java.util.List; public class MyBeanDefinitionParser2 extends AbstractSingleBeanDefinitionParser { private Class<?> clssze; public MyBeanDefinitionParser2(Class<?> cls) { this.clssze = cls; } @Override protected String getBeanClassName(Element element) { return clssze.getName(); } @Override protected void doParse(Elementelement, ParserContext parserContext, BeanDefinitionBuilder builder) { List<Element> els = DomUtils.getChildElements(element); NamedNodeMap nnm = element.getAttributes(); for (int i = 0; i <nnm.getLength(); i++) { Node node = nnm.item(i); String key = node.getLocalName(); String value = node.getNodeValue(); if ("id".equals(key)) { continue; } if ("entity".equals(key)){ if(parserContext.getRegistry().containsBeanDefinition(value)) { builder.addPropertyValue(key,parserContext.getRegistry().getBeanDefinition(value)); }else{ builder.addPropertyReference(key,value); } }else{ builder.addPropertyValue(key,value); } } for (Element element2 :els) { String name = element2.getAttribute("name"); String value = element2.getAttribute("value"); String ref = element2.getAttribute("ref"); if (!StringUtils.hasText(ref)){ builder.addPropertyValue(name,value); }else{ if(parserContext.getRegistry().containsBeanDefinition(ref)) { builder.addPropertyValue(name,parserContext.getRegistry().getBeanDefinition(ref)); }else{ builder.addPropertyReference(name,ref); } } } } }
SpringBean的Xml修改成如下:
<?xml version="1.0"encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xmlns:mi="http://www.ruishenh.com/custom/mytest" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.ruishenh.com/custom/mytesthttp://www.ruishenh.com/custom/mytest/myTest2.xsd"> <mi:executor address="127.0.0.1" name="myexecutor"id="myexecutor"> <property name="interval" value="5000"/> <property name="delay" value="2000"/> <property name="entity" ref="mye"/> </mi:executor> <mi:executor address="192.168.201.23" name="myexecutor2" id="myexecutor2" entity="mye2"> <property name="interval" value="5000"/> <property name="delay" value="2000"/> </mi:executor> <mi:entity name="mye" id="mye"> <property name="dbTypeID" value="1"/> <property name="dbTypeName" value="mysql" /> <property name="splitBy" value="id"/> <property name="sql" value="1"/> </mi:entity> <mi:entity name="mye2" id="mye2"> <property name="dbTypeID" value="2"/> <property name="dbTypeName" value="oracle" /> <property name="splitBy" value="orderId"/> <property name="sql" value="select * fromtablename" /> </mi:entity> </beans>
测试类:
packagecom.ruishenh.spring.test; importorg.springframework.context.support.FileSystemXmlApplicationContext; importcom.ruishenh.spring.config.MyEntity; importcom.ruishenh.spring.config.MyExecutor; publicclass Test { public static void main(String[] args) { String conf ="classpath:spring/myTest2.xml"; FileSystemXmlApplicationContext ac = newFileSystemXmlApplicationContext(conf); MyExecutor me = (MyExecutor)ac.getBean("myexecutor2"); MyExecutor me2 = (MyExecutor)ac.getBean("myexecutor"); System.out.println(me.toString()); System.out.println(me2.toString()); MyEntity mye = (MyEntity) ac.getBean("mye"); MyEntity mye2 = (MyEntity)ac.getBean("mye2"); System.out.println(mye.toString()); System.out.println(mye2.toString()); } }
运行结果:
MyExecutor[name=myexecutor2,delay=2000,interval=5000,address=192.168.201.23,entity=MyEntity[dbTypeID=2,dbTypeName=oracle,splitBy=orderId,sql=select* from tablename,name=mye2]]
MyExecutor[name=myexecutor,delay=2000,interval=5000,address=127.0.0.1,entity=MyEntity[dbTypeID=1,dbTypeName=mysql,splitBy=id,sql=1,name=mye]]
MyEntity[dbTypeID=1,dbTypeName=mysql,splitBy=id,sql=1,name=mye]
MyEntity[dbTypeID=2,dbTypeName=oracle,splitBy=orderId,sql=select* from tablename,name=mye2]
实体类和基本信息在:http://blog.csdn.net/ruishenh/article/details/33741501