XML-RPC - Anforderungsformat
XML-RPC-Anforderungen sind eine Kombination aus XML-Inhalten und HTTP-Headern. Der XML-Inhalt verwendet die Datentypisierungsstruktur zum Übergeben von Parametern und enthält zusätzliche Informationen, die angeben, welche Prozedur aufgerufen wird, während die HTTP-Header einen Wrapper zum Übergeben der Anforderung über das Web bereitstellen.
Jede Anforderung enthält ein einzelnes XML-Dokument, dessen Stammelement ein methodCall- Element ist. Jedes methodCall- Element enthält ein methodName- Element und ein params- Element. Das Element methodName gibt den Namen der aufzurufenden Prozedur an, während das Element params eine Liste der Parameter und ihrer Werte enthält. Jedes params Element enthält eine Liste von Elementen , die param wiederum enthalten Wert Elemente.
Um beispielsweise eine Anforderung an eine Methode namens circleArea zu übergeben , die einen Double- Parameter (für den Radius) verwendet, sieht die XML-RPC-Anforderung folgendermaßen aus:
<?xml version="1.0"?>
<methodCall>
<methodName>circleArea</methodName>
<params>
<param>
<value><double>2.41</double></value>
</param>
</params>
</methodCall>
Die HTTP-Header für diese Anforderungen spiegeln die Absender und den Inhalt wider. Die grundlegende Vorlage sieht wie folgt aus:
POST /target HTTP 1.0
User-Agent: Identifier
Host: host.making.request
Content-Type: text/xml
Content-Length: length of request in bytes
Wenn die circleArea-Methode beispielsweise von einem XML-RPC-Server verfügbar war , der / xmlrpc überwacht , sieht die Anforderung möglicherweise folgendermaßen aus:
POST /xmlrpc HTTP 1.0
User-Agent: myXMLRPCClient/1.0
Host: 192.168.124.2
Content-Type: text/xml
Content-Length: 169
Zusammengesetzt würde die gesamte Anfrage folgendermaßen aussehen:
POST /xmlrpc HTTP 1.0
User-Agent: myXMLRPCClient/1.0
Host: 192.168.124.2
Content-Type: text/xml
Content-Length: 169
<?xml version="1.0"?>
<methodCall>
<methodName>circleArea</methodName>
<params>
<param>
<value><double>2.41</double></value>
</param>
</params>
</methodCall>
Es ist eine gewöhnliche HTTP-Anfrage mit einer sorgfältig konstruierten Nutzlast.