XML-RPC

XML-RPCとは、遠隔手続き呼出し (RPC) プロトコルの一種であり、エンコード(符号化)にXMLを採用し、転送機構にHTTPを採用している。非常に単純なプロトコルで、少数のデータ型やコマンドだけを定義しているだけであり、その仕様は2枚の紙にまとめられる。これは多くのRPCシステムが膨大な量の規格を規定し、実装に多量のプログラミングを要することに比べると、際立った特徴と言える。

1998年、ユーザーランド・ソフトウェアがマイクロソフトと共同で開発した。その後、これに新たな機能を追加したものがSOAPへと発展した。しかし、SOAP よりも単純で扱いやすいXML-RPCを好む人もいる。

類似の RPCプロトコルとして JSON-RPC がある。

データ型

名称タグ使用例説明
array
<array>  <data>    <value><i4>1404</i4></value>    <value><string>Something here</string></value>    <value><i4>1</i4></value>  </data></array>
値の配列。キーは格納しない。
base64
<base64>eW91IGNhbid0IHJlYWQgdGhpcyE=</base64>
Base64でエンコードされたバイナリデータ
boolean
<boolean>1</boolean>
ブーリアン型の論理値(0または1)
date/time
<dateTime.iso8601>19980717T14:08:55</dateTime.iso8601>
日付と時刻
double
<double>-12.53</double>
倍精度浮動小数点数
integer
<i4>42</i4>

または

<int>42</int>
整数
string
<string>Hello world!</string>
文字列。XMLのエンコード規則に従う。
struct
<struct>  <member>    <name>foo</name>    <value><i4>1</i4></value>  </member>  <member>    <name>bar</name>    <value><i4>2</i4></value>  </member></struct>
キーを含む値の配列。
nil
<nil/>
NULL値の識別用。XML-RPC の拡張

XML-RPC要求の典型例を以下に示す。

<?xml version="1.0"?><methodCall>  <methodName>examples.getStateName</methodName>  <params>    <param>        <value><i4>40</i4></value>    </param>  </params></methodCall>

XML-RPC応答の典型例を以下に示す。

<?xml version="1.0"?><methodResponse>  <params>    <param>        <value><string>South Dakota</string></value>    </param>  </params></methodResponse>

XML-RPCフォールトの典型例を以下に示す。

<?xml version="1.0"?><methodResponse>  <fault>    <value>      <struct>        <member>          <name>faultCode</name>          <value><int>4</int></value>        </member>        <member>          <name>faultString</name>          <value><string>Too many parameters.</string></value>        </member>      </struct>    </value>  </fault></methodResponse>

関連項目

外部リンク