开发者

xsi:type in doc literal format

开发者 https://www.devze.com 2023-01-12 15:05 出处:网络
Although in normal circumstances xsi:type does not appear in a literal WSDL\'s SOAP message, there are still cases when type information is necessary and it will appear -- in polymorphism, for instanc

Although in normal circumstances xsi:type does not appear in a literal WSDL's SOAP message, there are still cases when type information is necessary and it will appear -- in polymorphism, for instance. If the API expects a base type and an extension instance is sent, the type of that instance must be provided for proper deserialization of the object.

My question: How valid is to send xsi:type in doc/literal format? Is it possible to find an official answer (positive/negative)? What are your thoughts?

example:

<Device xsi:type="ns1:DeviceID">value</Device>

instead o开发者_Python百科f

<Device>value</Device>


The xsi:type attribute is normally not necessary since the XSD schema contained in the WSDL's types section is enough information for the client/server to figure out the type of all the elements.

But consider that there is sometimes the need to have a field or element as being of any type (xsd:anyType) so that you can use polymorphism (as you mentioned yourself).

For example, you might have a web service that runs some commands sent to it inside an XML field marked as xsd:anyType. Such a service specifies nothing about the type of the data at design time so instead type information must be provided at runtime.

Of course such a service does not accept absolutely any type but work with set of predefined types (i.e. so that you don't send it just any crap; just valid commands from a set of command types).

But the XML part is just communication. You eventually have to do something with that type programmaticaly, in client/server code. That means converting the xsd:anyType to an object in a programming language.

A WSDL-To-Code tool usually maps an xsd:anyType to the a top Object class which frankly isn't that useful. For that reason, an xsd:anyType is always serialized along with an xsi:type that specifies the actual type so that your code knows what the heck is in there.

As to how valid it is send xsi:type in doc/literal format my answer is: I'm thinking it is valid. WSDL and SOAP specifications mention nothing specific related to this (as to prohibit it), and the WS-Interoperability specification allows it.

So I think xsi:type it is not something positive or negative but just a tool for the job.


I think this use is discouraged. Generally in web services, the element name and position dictate it's type. It does make sense to leave room in a schema for expansion using "any".

<sequence>
<element name="a" type="AType"
<element name="b" type="BType"
<any minOccurs="0"

This allows for the possibility of sending additional information at a latter time without making the document invalid.

Let's consider a case where you are extending a class, AddressType, that is defined in schema

<address xs:type="USAddressType">
   <name
   <line1

Basically I (your partner) will have to write custom validation for this, so I would prefer to get an XSD that contains all known the extensions so I can use my standard validation libraries.

0

精彩评论

暂无评论...
验证码 换一张
取 消