Rant continued again: Don't put XML in Strings
Shaun's post reminds me of two points to make about my aversion to HTML-encoding XML into strings and then returning the strings from your Web service instead of returning the XML:
- Web services are all about wire format and are not about what objects you use to expose our consume your Web service. That is why SOAP 1.2 is called SOAP and not the Simple Object Access Protocol. So the fact that an Account object was used in .NET and that you are consuming the Web service on something other than .NET is beside the point. You did not mention what toolkit you are using, but pretty much all of them can deal with XML in the body of the request as well as they can deal with an HTML-encoded string in one of the text nodes in the XML in the body of the request.
- This is not just advice for those of you using .NET to create Web services. This applies to ALL Web services on all platforms.
-Matt
Comments
- Anonymous
May 14, 2004
Here is the SDL for MS's CRM app in case you haven't seen it. They do exactly what you are saying not to do, unless I am interprating it wrong.
Check out CRMAccount. They have sample calls.
http://msdn.microsoft.com/library/default.asp?url=/library/en-us/CrmSdk1_2/htm/v1d2microsoftcrmplatformproxyclasses.asp
http://msdn.microsoft.com/library/default.asp?url=/library/en-us/CrmSdk1_2/htm/v1d2objectschemas.asp - Anonymous
May 14, 2004
Your right. But they did this largely due to the lack of early tool support...and they have had to live with this problem.
As mentioned in my earlier post (http://blogs.msdn.com/mpowell/archive/2004/05/13/131377.aspx)...they have repented.
-Matt