1.1.1 wsdl扩展实现结构
我们知道,在WSDL的标准namespace(xmlns=http://schemas.xmlsoap.org/wsdl/)中,有types,message和portType等标签。但在BPEL标准的wsdl部分,还有一个很重要的标签,那就是partnerLinkType。partnerLinkType是wsdl本身不包括的扩展部分,那这些扩展部分在jBPM BPEL中是怎么样来实现的呢?我们先来看看下面的jBPM BPEL的WSDL实现层次结构图:(这个内容是HongSoft本人正在写的一本工作流书中的一小块的草稿。图这里发不了,sorry。这里写的不太容易懂,和和,其他部分比较容易懂)
javax.wsdl.*
(Sun主导制定的规范接口)
com.ibm.wsdl.*
(IBM的wsdl标准实现)
org.jbpm.bpel.wsdl.*
(jBPM bpel对wsdl的扩展)
最顶层是javax.wsdl.*,是在JSR中制定的WSDL规范的接口表达,在jBPM BPEL代码中对应于wsdl4j.jar。第二层是com.ibm.wsdl.*,是IBM公司对wsdl标准的一个实现,基本上没有加入自己的任何扩展,在jBPM BPEL代码中对应于wsdl4j.jar。最底层是jBPM对BPEL中WSDL部分的扩展实现,它使用了wsdl4j.jar,然后加入了特殊部分的解析。
1.1.2扩展点注册器
扩展点注册器(ExtensionRegistry)是WSDL本身的概念,WSDL使用它来注册新的扩展点。在wsdl4j.jar的WSDLFactoryImpl.java中,实现了ExtensionRegistry功能,而jBPM就是使用IBM的这个注册器实现加入了三个扩展点,wsdl4j.jar的实现结构如下::(这个内容是HongSoft本人正在写的一本工作流书中的一小块的草稿。图这里发不了,sorry。这里写的不太容易懂,和和,其他部分比较容易懂)
1.1.3 扩展点
一个扩展点注册器可以注册多个扩展点。扩展点的意思是需要新加入的WSDL标准中没有规定的新的标签,比如BPEL的partnerLinkType就是一个扩展点。
每注册一个扩展点需要确定三个方面的内容:
1)在本流程中,需要能够把一个partnerLinkType对象序列化为对应的XML文件,这个XML文件用来在网络中传送,然后到对方流程中反序列化。比如对于partnerLinkType扩展点的实现为registry.registerSerializer(Definition.class, WsdlConstants.Q_PARTNER_LINK_TYPE, plinkTypeSerializer);这里的plinkTypeSerializer是一个扩展了ExtensionSerializer接口的类。而ExtensionSerializer接口要求必须实现marshall()方法的。
2)如前面所述,对方流程需要能够把XML文件反序列化为partnerLinkType对象。比如对于partnerLinkType扩展点的实现为registry.registerDeserializer(Definition.class, WsdlConstants.Q_PARTNER_LINK_TYPE, plinkTypeSerializer); 这里的plinkTypeSerializer是一个扩展了ExtensionDeserializer接口的类。而ExtensionDeserializer接口要求必须实现unmarshall ()方法的。
3) 序列化和反序列化的方法中,都只需要给出对应的partnerLinkType对象的接口就可以了,而真正的使用是需要具体类的。BPEL的WSDL扩展实现了QName和具体类的映射关系如下:registry.mapExtensionTypes(Definition.class, WsdlConstants.Q_PARTNER_LINK_TYPE, PartnerLinkTypeImpl.class);这里的PartnerLinkTypeImpl是实现了PartnerLinkType接口的具体类。而PartnerLinkType接口是在marshall()方法和unmarshall ()方法中需要使用的。
1.1.4 BPEL的WSDL扩展点
jBPM对WSDL加了三个扩展点,分别用来实现PartnerLinkType功能,Property功能和PropertyAlias功能。具体如下图表所示:
QName
序列化
反序列化
映射类
WsdlConstants.
Q_PARTNER_LINK_TYPE
PartnerLinkType
Serializer
PartnerLinkType
Serializer
PartnerLinkTypeImpl
WsdlConstants.
Q_PROPERTY
Property
Serializer
Property
Serializer
PropertyImpl
WsdlConstants.
Q_PROPERTY_ALIAS
PropertyAlias
Serializer
PropertyAlias
Serializer
PropertyAliasImpl
QName表示“qualified name”,它由两部分组成:1)name所在的name space;2)name在XML中的元素(element)名称。一个QName对应一个扩展点,而扩展点注册器(ExtensionRegistry)用QName作为key值的map来保存全部的扩展点。
jBPM中的序列化和反序列化组件都是同时实现了ExtensionDeserializer,ExtensionSerializer, Serializable这三个接口,分开实现其实也是可以的。
映射类用来做到接口与实现的分离,每个映射类都对应了一个接口,这个接口才是jBPM的其他部分所大量使用的。