我们知道,在WSDL的标准namespace(xmlns=http://schemas.xmlsoap.org/wsdl/)中,有types,message和portType等标签。但在BPEL标准的wsdl部分,还有一个很重要的标签,那就是partnerLinkType。partnerLinkType是wsdl本身不包括的扩展部分,那这些扩展部分在jBPM BPEL中是怎么样来实现的呢?我们先来看看下面的jBPM BPEL的WSDL实现层次结构图:(这个内容是HongSoft本人正在写的一本工作流书中的一小块的草稿。图这里发不了,sorry。这里写的不太容易懂,和和,其他部分比较容易懂)
<group id="_x0000_s1026" style="width: 414pt; height: 241.8pt;" coordsize="7200,4212" coordorigin="2362,7008" editas="canvas"><lock aspectratio="t" v:ext="edit"></lock><shapetype id="_x0000_t75" coordsize="21600,21600" stroked="f" filled="f" path="m@4@5l@4@11@9@11@9@5xe" o:preferrelative="t" o:spt="75"><stroke joinstyle="miter"></stroke><formulas><f eqn="if lineDrawn pixelLineWidth 0"></f><f eqn="sum @0 1 0"></f><f eqn="sum 0 0 @1"></f><f eqn="prod @2 1 2"></f><f eqn="prod @3 21600 pixelWidth"></f><f eqn="prod @3 21600 pixelHeight"></f><f eqn="sum @0 0 1"></f><f eqn="prod @6 1 2"></f><f eqn="prod @7 21600 pixelWidth"></f><f eqn="sum @8 21600 0"></f><f eqn="prod @7 21600 pixelHeight"></f><f eqn="sum @10 21600 0"></f></formulas><path o:connecttype="rect" gradientshapeok="t" o:extrusionok="f"></path><lock aspectratio="t" v:ext="edit"></lock></shapetype><shape id="_x0000_s1027" style="left: 2362px; width: 7200px; position: absolute; top: 7008px; height: 4212px;" o:preferrelative="f" type="#_x0000_t75"><font size="3"><font face="宋体"><fill o:detectmouseclick="t"></fill><path o:connecttype="none" o:extrusionok="t"></path><lock v:ext="edit" text="t"></lock></font></font></shape><rect id="_x0000_s1028" style="left: 4240px; width: 2818px; position: absolute; top: 7144px; height: 1087px;"><textbox></textbox></rect></group>
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,然后加入了特殊部分的解析。
扩展点注册器(ExtensionRegistry)是WSDL本身的概念,WSDL使用它来注册新的扩展点。在wsdl4j.jar的WSDLFactoryImpl.java中,实现了ExtensionRegistry功能,而jBPM就是使用IBM的这个注册器实现加入了三个扩展点,wsdl4j.jar的实现结构如下::(这个内容是HongSoft本人正在写的一本工作流书中的一小块的草稿。图这里发不了,sorry。这里写的不太容易懂,和和,其他部分比较容易懂)
<shape id="_x0000_i1026" style="width: 408pt; height: 114pt;" type="#_x0000_t75"><imagedata o:title="" src="file:///C:%5CDOCUME%7E1%5CADMINI%7E1%5CLOCALS%7E1%5CTemp%5Cmsohtml1%5C01%5Cclip_image002.png"><font face="宋体" size="3"></font></imagedata></shape>
一个扩展点注册器可以注册多个扩展点。扩展点的意思是需要新加入的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 ()方法中需要使用的。
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 的其他部分所大量使用的。