了解WSDL中的style和use

阅读更多

1.   Styleuse的组合

 

use属性可以为literalencodedstyle可以为rpcdocument,我们来对五种类型的style/use决定的binding作一比较,分别是rpc/literal, document/literal none-wrapper, document/literal with wrapper, rpc/encoded, 以及document/encoded

从生成soap消息的角度看,rpcdocument的差别在于方法的操作名是否出现在生成的Soap消息中,encodedliteral编码方式的差别在于参数类型是否出现在生成的Soap消息中。

这样rpc/encoded能够完整地表示一个方法调用,但缺点是性能很差,而且不能校验Soap消息的有效性。

rpc/literal不对参数类型进行编码,但仍然无法对Soap消息进行校验。Document/encoded没有意义,因为没有方法名,对参数类型编码没有什么意义。

document/literal none-wrapper无法生成操作名,适用于完整的文档作为参数传递给方法的场景。

document/literal with wrapper应该是目前使用最多的方式,在xfire中也是默认配置。

2.   示例

 

2.1. Java方法

 

public void myMethod(int x);

2.2. Rpc/encoded

 

Rpc风格的特点是message元素的每一个part都必须用type属性定义。encoded用来指明一个类型编码模型,不依赖于XML Schema

清单 2. 用于 myMethod RPC/编码的 WSDL

   

   

       

       

   

 

 

现在用“5”作为参数 x 的值来调用此方法。我们将发送一个与 清单3类似的 SOAP 消息。

清单 3. 用于 myMethod RPC/编码的 SOAP 消息

   

       

            5

       

   

 

2.3. RPC/文字

 

用于我们的方法的 RPC/文字的 WSDL 看起来与 RPC/编码的 WSDL 几乎一样。只是绑定的用法由 编码改为 文字。仅此而已。

4. 用于 myMethod RPC/文字的 WSDL

   

   

       

       

   

 

     

 

RPC/文字的 SOAP 消息去掉了类型编码。

清单 5. 用于 myMethod RPC/文字的 SOAP 消息

   

       

            5

       

   

 

2.4. document/literal

 

document/literal的主要特点是message元素的每一个part都使用element属性引用一个types下面定义的schema元素。

清单6. 用于 myMethod 的文档/文字的 WSDL

   

       

   

    element="xElement"/>

   

       

       

   

 

     

清单7. 用于 myMethod 的文档/文字的 SOAP 消息

   

        5

你可能感兴趣的:(SOAP)