PerlでWeb APIを使いたおす 2

XML-RPCサーバーの実装

XML-RPCサーバーの実装


   続いてはXML-RPCサーバーを実装してみることにしましょう。RPC-XMLモジュールにはサーバーを立てるためのツールも用意されているので、それを利用します。

   今回作成したのは2つの整数を受け取ってそれを足し算して返す「example.sum」というメソッドです。まずはサンプルを見てみることにしましょう(リスト9)。


リスト9:XML-RPCサーバーのサンプル
#!/usr/bin/perl
use RPC::XML::Server;
my $host = "www.example.com";
my $port = "9001";
my $server = RPC::XML::Server->new(
      host => $host,
      port => $port,
);

my $example_sum = RPC::XML::Procedure->new(
    { name      => 'example.sum',
      code      => \&example_sum,
      signature => ['i4 i4 i4'] }
);
$server->add_method($example_sum);
$server->server_loop;

sub example_sum {
      my ($num1, $num2 ) = @_;
      return $num1 + $num2;
}

   まずはサーバーのホスト名とポート番号を指定してRPC::XML::Serverクラスのインスタンスを作ります。続いてadd_methodメソッドで提供するメソッドを追加していきます。メソッドを追加するにはまずRPC::XML::Procedureクラスのインスタンスを作ります。作成の際にはメソッドの名前、呼び出されるサブルーチン、パラメータを指定します。パラメータの指定は、戻り値と渡すパラメータをスペース区切りの文字列として渡します。

   最後にserver_loopを呼び出せば、サーバーはクライアントからのアクセスを待ち受ける状態となります。

   クライアントからの要求があったときに実際に呼び出されるサブルーチンexample_sumでは、引数に実際に渡されたパラメータが入ります。XMLとの相互変換等は全てXML-RPCがやってくれるため、通常のサブルーチンとほぼ同じように書けるのが特長です。

   なお、このAPIにアクセスするクライアントはリスト10のようになるでしょう。

リスト10:example.sumにアクセスするクライアント
#!/usr/bin/perl
use strict;
use warnings;
use RPC::XML::Client;

my $client = RPC::XML::Client->new('http://www.example.com:9001/');
my $req = RPC::XML::request->new(
  'example.sum',
  RPC::XML::i4->new('10'),
  RPC::XML::i4->new('23'),
);

my $res = $client->send_request($req);
if( $res->is_fault ){
    print "ERROR: ".$res->value->{faultString}."\n";
}else{
    print "SUM: ".$res->value."\n";
}

   リスト9に示したサンプルは、独自のWebサーバーを立ち上げるものです。しかしすでにサーバーが立ち上がっていて、あるURLへのアクセスのみをXML-RPCのリクエストとして処理したい場合には、受け取ったデータをRPC::XML::Parserだけを使って処理することも可能です(リスト11)。

リスト11:データの処理をRPC::XML::Parserで行う
my $reqobj = RPC::XML::Parser->new->parse($request);
my $name = $reqobj->name;
my @args = map {$_->value} @{$reqobj->args};
my $response = example_sum(@args);
my $resobj = RPC::XML::response->new($response);

   RPC::XML::Parserは渡されてきたXMLデータ(ここでは$requestに格納されていると仮定しています)を解析してメソッド名とパラメータを取り出してくれます。パラメータはRPC::XML::stringのなどのオブジェクトになっているので、valueメソッドを利用すればデータを取り出すことができます。structはハッシュとして、arrayは配列として取り出せるようになっているので、後はそれを処理して(ここではexample_sumを呼び出しています)、結果を返すだけです。結果をXMLデータに変換するには、RPC::XML::responseクラスを利用すれば簡単です。

この記事をシェアしてください

人気記事トップ10

人気記事ランキングをもっと見る