XML-RPC


XML-RPC is a remote procedure call protocol which uses XML to encode its calls and HTTP as a transport mechanism.

History

The XML-RPC protocol was created in 1998 by Dave Winer of UserLand Software and Microsoft, with Microsoft seeing the protocol as an essential part of scaling up its efforts in business-to-business e-commerce. As new functionality was introduced, the standard evolved into what is now SOAP.
UserLand supported XML-RPC from version 5.1 of its Frontier web content management system, released in June 1998.
XML-RPC's idea of a human-readable-and-writable, script-parsable standard for HTTP-based requests and responses has also been implemented in competing specifications such as Allaire's Web Distributed Data Exchange and webMethod's Web Interface Definition Language. Prior art wrapping COM, CORBA, and Java RMI objects in XML syntax and transporting them via HTTP also existed in DataChannel's WebBroker technology.
The generic use of XML for remote procedure call was patented by Phillip Merrick, Stewart Allen, and Joseph Lapp in April 2006, claiming benefit to a provisional application filed in March 1998. The patent was assigned to webMethods, located in Fairfax, VA. The patent expired on 23 March 2019

Usage

In XML-RPC, a client performs an RPC by sending an HTTP request to a server that implements XML-RPC and receives the HTTP response. A call can have multiple parameters and one result. The protocol defines a few data types for the parameters and result. Some of these data types are complex, i.e. nested. For example, you can have a parameter that is an array of five integers.
The parameters/result structure and the set of data types are meant to mirror those used in common programming languages.
Identification of clients for authorization purposes can be achieved using popular HTTP security methods. Basic access authentication can be used for identification and authentication.
In comparison to RESTful protocols, where resource representations are transferred, XML-RPC is designed to call methods. The practical difference is just that XML-RPC is much more structured, which means common library code can be used to implement clients and servers and there is less design and documentation work for a specific application protocol. One salient technical difference between typical RESTful protocols and
XML-RPC is that the RESTful protocol uses the HTTP URI for parameter information whereas with XML-RPC, the URI just identifies the server.
JSON-RPC is similar to XML-RPC.

Data types

Common datatypes are converted into their XML equivalents with example values shown below:
NameTag ExampleDescription
array



1404
Something here
1


Array of values, storing no keys
base64

eW91IGNhbid0IHJlYWQgdGhpcyE=
Base64-encoded binary data
boolean

1
Boolean logical value
date/time

19980717T14:08:55
Date and time in ISO 8601 format
double

-12.53
Double precision floating point number
integer

42

or

42
Whole number, integer
string

Hello world!

or

Hello world!
String of characters. Must follow XML encoding.
struct



foo
1


bar
2


Associative array
nil


Discriminated null value; an XML-RPC

Examples

An example of a typical XML-RPC request would be:



examples.getStateName


40




An example of a typical XML-RPC response would be:





South Dakota




A typical XML-RPC fault would be:







faultCode
4


faultString
Too many parameters.





Criticism

Recent critics of XML-RPC argue that RPC calls can be made with plain XML, and that XML-RPC does not add any value over XML. Both XML-RPC and XML require an application-level data model, such as which field names are defined in the XML schema or the parameter names in XML-RPC. Furthermore, XML-RPC uses about 4 times the number of bytes compared to plain XML to encode the same objects, which is itself verbose compared to JSON.