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.