微服务框架开发(二)—扩展spring schema
                                                            生活随笔
收集整理的這篇文章主要介紹了
                                微服务框架开发(二)—扩展spring schema
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.                        
                                2019獨角獸企業重金招聘Python工程師標準>>>
一、實體bean的定義 回顧一下我們需要定義的4個標簽
- 定義注冊中心標簽:
- 定義服務協議標簽
- 定義服務提供標簽:
- 定義服務引用標簽:
UML圖設計如下
- RegistyConfig、ServiceConfig、RefererConfig分別繼承自抽象類AbstractConfig,并分別定義了三個標簽的相關屬性。ServiceConfigBean、RefererConfigBean用于實現spring的相關接口,達到對配置文件中bean進行處理的目的。
二、定義xsd文件(xmen.xsd)
<?xml version="1.0" encoding="UTF-8"?> <xsd:schema xmlns="http://www.solid4j.com/schema/xmen" xmlns:xsd="http://www.w3.org/2001/XMLSchema"xmlns:tool="http://www.springframework.org/schema/tool" xmlns:beans="http://www.springframework.org/schema/beans"targetNamespace="http://www.solid4j.com/schema/xmen"><xsd:import namespace="http://www.w3.org/XML/1998/namespace" /><xsd:import namespace="http://www.springframework.org/schema/tool" /><xsd:import namespace="http://www.springframework.org/schema/beans" /><xsd:complexType name="abstractConfig"><xsd:anyAttribute /></xsd:complexType><xsd:complexType name="abstractRegistryConfig"><xsd:complexContent><xsd:extension base="abstractConfig"><xsd:attribute name="id" type="xsd:ID" /><xsd:attribute name="name" type="xsd:string" use="optional"><xsd:annotation><xsd:documentation><![CDATA[ 注冊名稱. ]]></xsd:documentation></xsd:annotation></xsd:attribute><xsd:attribute name="regProtocol" type="xsd:string"use="optional"><xsd:annotation><xsd:documentation><![CDATA[ 注冊協議. ]]></xsd:documentation></xsd:annotation></xsd:attribute><xsd:attribute name="address" type="xsd:string" use="optional"><xsd:annotation><xsd:documentation><![CDATA[ 注冊中心地址. ]]></xsd:documentation></xsd:annotation></xsd:attribute><xsd:attribute name="connectTimeout" type="xsd:integer"use="optional"><xsd:annotation><xsd:documentation><![CDATA[ 注冊中心連接超時時間(毫秒). ]]></xsd:documentation></xsd:annotation></xsd:attribute></xsd:extension></xsd:complexContent></xsd:complexType><xsd:complexType name="abstractProtocolConfig"><xsd:complexContent><xsd:extension base="abstractConfig"><xsd:attribute name="id" type="xsd:ID" /><xsd:attribute name="name" type="xsd:string" use="optional"><xsd:annotation><xsd:documentation><![CDATA[ 協議名稱. ]]></xsd:documentation></xsd:annotation></xsd:attribute><xsd:attribute name="port" type="xsd:integer" use="optional"><xsd:annotation><xsd:documentation><![CDATA[ 服務端口 ]]></xsd:documentation></xsd:annotation></xsd:attribute></xsd:extension></xsd:complexContent></xsd:complexType><xsd:complexType name="abstractServiceConfig"><xsd:complexContent><xsd:extension base="abstractConfig"><xsd:attribute name="id" type="xsd:ID" /><xsd:attribute name="interface" type="xsd:token"><xsd:annotation><xsd:documentation><![CDATA[ 定義接口,在注冊中心中注冊 ]]></xsd:documentation><xsd:appinfo><tool:annotation><tool:expected-type type="java.lang.Class" /></tool:annotation></xsd:appinfo></xsd:annotation></xsd:attribute><xsd:attribute name="ref" type="xsd:string" use="optional"><xsd:annotation><xsd:documentation><![CDATA[ 接口實現 ]]></xsd:documentation></xsd:annotation></xsd:attribute><xsd:attribute name="class" type="xsd:string" use="optional"><xsd:annotation><xsd:documentation><![CDATA[ 接口實現 ]]></xsd:documentation></xsd:annotation></xsd:attribute></xsd:extension></xsd:complexContent></xsd:complexType><xsd:complexType name="abstractRefererConfig"><xsd:complexContent><xsd:extension base="abstractConfig"><xsd:attribute name="id" type="xsd:ID" /><xsd:attribute name="interface" type="xsd:token" use="required"><xsd:annotation><xsd:documentation><![CDATA[ 調用的接口 ]]></xsd:documentation><xsd:appinfo><tool:annotation><tool:expected-type type="java.lang.Class" /></tool:annotation></xsd:appinfo></xsd:annotation></xsd:attribute></xsd:extension></xsd:complexContent></xsd:complexType><xsd:element name="registry" type="abstractRegistryConfig"><xsd:annotation><xsd:documentation><![CDATA[ 注冊中心配置 ]]></xsd:documentation></xsd:annotation></xsd:element><xsd:element name="protocol" type="abstractProtocolConfig"><xsd:annotation><xsd:documentation><![CDATA[ 服務協議 ]]></xsd:documentation></xsd:annotation></xsd:element><xsd:element name="service" type="abstractServiceConfig"><xsd:annotation><xsd:documentation><![CDATA[ 服務配置 ]]></xsd:documentation></xsd:annotation></xsd:element><xsd:element name="referer" type="abstractRefererConfig"><xsd:annotation><xsd:documentation><![CDATA[ 引用服務配置 ]]></xsd:documentation></xsd:annotation></xsd:element> </xsd:schema>三、定義handler處理文件(spring.schemas和spring.handlers)
http\://www.solid4j.com/schema/xmen.xsd=META-INF/xmen.xsdhttp\://www.solid4j.com/schema/xmen=com.solid4j.xmen.config.spring.handler.XmenNamespaceHandler四、編寫具體的Handler類
public class XmenNamespaceHandler extends NamespaceHandlerSupport {@Overridepublic void init() {registerBeanDefinitionParser("registry", new XmenBeanDefinitionParser(RegistryConfig.class, true));registerBeanDefinitionParser("protocol", new XmenBeanDefinitionParser(ProtocolConfig.class, true));registerBeanDefinitionParser("service", new XmenBeanDefinitionParser(ServiceConfigBean.class, true));registerBeanDefinitionParser("referer", new XmenBeanDefinitionParser(RefererConfigBean.class, false));} } public class XmenBeanDefinitionParser implements BeanDefinitionParser {private static final Logger LOGGER = LoggerFactory.getLogger(BeanDefinitionParser.class);private final Class<?> beanClass;private final boolean required;public XmenBeanDefinitionParser(Class<?> beanClass, boolean required) {this.beanClass = beanClass;this.required = required;}@Overridepublic BeanDefinition parse(Element element, ParserContext parseContext) {try {return parse(element, parseContext, beanClass, required);} catch (ClassNotFoundException e) {e.printStackTrace();}return null;}private BeanDefinition parse(Element element, ParserContext parserContext, Class<?> beanClass, boolean required) throws ClassNotFoundException {RootBeanDefinition bd = new RootBeanDefinition();bd.setBeanClass(beanClass);bd.setLazyInit(false);String id = element.getAttribute("id");if ((id == null || id.length() == 0) && required) {String generatedBeanName = element.getAttribute("name");if (generatedBeanName == null || generatedBeanName.length() == 0) {generatedBeanName = element.getAttribute("class");}if (generatedBeanName == null || generatedBeanName.length() == 0) {generatedBeanName = beanClass.getName();}id = generatedBeanName;int counter = 2;while (parserContext.getRegistry().containsBeanDefinition(id)) {id = generatedBeanName + (counter++);}}if (id != null) {if (parserContext.getRegistry().containsBeanDefinition(id)) {throw new IllegalStateException("Duplicate spring bean config, id = " + id);}parserContext.getRegistry().registerBeanDefinition(id, bd);}bd.getPropertyValues().addPropertyValue("id", id);if(ServiceConfigBean.class.equals(beanClass)) {String className = element.getAttribute("class");if(className != null && className.length() > 0) {RootBeanDefinition classDefinition = new RootBeanDefinition();classDefinition.setBeanClass(Class.forName(className, true, Thread.currentThread().getContextClassLoader()));classDefinition.setLazyInit(false);bd.getPropertyValues().addPropertyValue("ref", new BeanDefinitionHolder(classDefinition, id + "Impl"));}}for (Method setter : beanClass.getMethods()) {String name = setter.getName();if (name.length() <= 3 || !name.startsWith("set") || !Modifier.isPublic(setter.getModifiers())) {continue;}String property = name.substring(3, 4).toLowerCase() + name.substring(4);if ("id".equals(property)) {bd.getPropertyValues().addPropertyValue("id", id);continue;}String value = element.getAttribute(property);value = value.trim();if (value.length() == 0 || value == null) {continue;}Object reference;if ("ref".equals(property)) {reference = new RuntimeBeanReference(value);} else {reference = new TypedStringValue(value);}bd.getPropertyValues().addPropertyValue(property, reference);}return bd;} }轉載于:https://my.oschina.net/solidwang/blog/800964
總結
以上是生活随笔為你收集整理的微服务框架开发(二)—扩展spring schema的全部內容,希望文章能夠幫你解決所遇到的問題。
 
                            
                        - 上一篇: 自制题库答题考试软件小程序开发,把题库导
- 下一篇: 在用户态下使用uint64_t
