[Affelio-cvs 585] CVS update: affelio/apps/Mixi/extlib/WWW/Mixi

Back to archive index

Yoshihisa Fukuhara higef****@users*****
2005年 8月 29日 (月) 19:41:05 JST


Index: affelio/apps/Mixi/extlib/WWW/Mixi/Cookbook.pod
diff -u /dev/null affelio/apps/Mixi/extlib/WWW/Mixi/Cookbook.pod:1.1
--- /dev/null	Mon Aug 29 19:41:05 2005
+++ affelio/apps/Mixi/extlib/WWW/Mixi/Cookbook.pod	Mon Aug 29 19:41:05 2005
@@ -0,0 +1,455 @@
+=encoding utf8
+
+=head1 NAME
+
+WWW::Mixi::Cookbook - WWW::Mixiのクックブック
+
+=head1 DESCRIPTION
+
+このドキュメントにはWWW::Mixiの典型的な使い方を示すいくつかのサンプルが入っています。
+
+=head1 mixiからのデータ取得
+
+WWW::Mixiモジュールには、ログイン用のloginメソッドと、それから1メソッドで直接コメントなどを取得できるデータ取得メソッドがあります。
+これらを使うと、mixiへのアクセスは非常に簡単です。
+
+=head2 ログイン
+
+mixiへのログインは、loginコマンド一つで完了します。
+ログイン後には、LWP::UserAgentスタイルでのRequestメソッドやget、postメソッドでのmixiアクセスも、mixiからのデータ取得メソッドでのデータ取得も可能になります。
+
+ use WWW::Mixi;
+ use HTTP::Request::Common;
+ 
+ my $mixi = WWW::Mixi->new('me****@mixi*****', 'mixi_password');
+ 
+ print "ログインします。\n";
+ my $response = $mixi->login;
+
+=head2 マイミクシイ最新日記の取得
+
+mixiからの情報取得も、私がデータ取得メソッドと読んでいるいくつかの便利なメソッドで簡単に済ませることができます。
+すべてのデータ取得に対応しているわけではありませんが、それを使うのが一番簡単な方法です。
+
+まず、マイミクシイ最新日記用のデータ取得メソッド"get_new_friend_diary"を紹介しましょう。
+このメソッドは、次のような配列のリファレンスを返します。
+
+ {
+ 	'subject' => 'mixiの本。',
+ 	'link' => 'http://mixi.jp/list_item_review.pl?reviewer_id=xxxx&item_id=xxxxx',
+ 	'name' => '塚本牧生',
+ 	'time' => '2004/08/18 13:18'
+ }
+
+例として、マイミクシイ最新日記をテキストで出力するスクリプトを挙げましょう。
+
+ use WWW::Mixi;
+ 
+ my $mixi = WWW::Mixi->new('me****@mixi*****', 'mixi_password');
+ 
+ print "ログインします。\n";
+ my $response = $mixi->login;
+ 
+ print "マイミクシイ最新日記を取得します。\n";
+ my =item get_new_friend_diary;
+ print "マイミクシイ最新日記を出力します。\n";
+ foreach my $item (@items) {
+ 	my $subject = $item->{'subject'};
+ 	my $link = $item->{'link'};
+ 	my $name = $item->{'name'};
+ 	my $time = $item->{'time'};
+ 	print "■ $subject\n[日時] $time\n[名前] $name\n[Link] $link\n\n";
+ }
+
+ちょっと気を付けておきたいのは、mixiの文字コードがEUCだということです。
+Windowsのコマンドラインなどで使う時には、文字コードをSJISにしてやる必要があるでしょうから、その時はJcodeモジュールなども組合わせてみてください。
+
+=head2 その他のデータ取得メソッド
+
+マイミクシイ最新日記用のget_new_friend_diaryの他にも、いくつかのデータ取得メソッドがあります。
+以下は0.21版で利用できるデータ取得メソッドの一部ですが、基本的には後述の「parse_~」というメソッドには、対応する「get_~」メソッドがあると思ってまず間違いはありません。
+正確で完全な一覧は、ドキュメントを確認してください。
+
+多くのデータ取得メソッドは、get_new_friend_diaryと同じように引数なしで実行でき、それぞれ決まった形式の(でもget_new_friend_diaryと似た感じの)ハッシュリファレンスを複数返します。
+
+=over 4
+
+=item get_information
+
+ホームに表示される「管理者からのお知らせ」を取得します。
+
+=item get_list_comment
+
+最近のコメントに表示される「最近のコメント一覧」を取得します。
+
+=item get_list_message
+
+メッセージに表示される「受信箱」を取得します。
+
+=item get_new_bbs
+
+コミュニティ最新書き込みを取得します。
+
+=item get_new_comment
+
+日記コメント記入履歴を取得します。
+
+=item get_new_friend_diary
+
+マイミクシイ最新日記を取得します。
+
+=item get_new_review
+
+マイミクシイ最新レビューを取得します。
+
+=item get_show_log
+
+あしあとを取得します。
+
+=back
+
+例外として、メインメニュー項目を取得するget_main_menu、バナーを取得するget_banner、ツールバー項目を取得するget_tool_barの3つは、引数でURLを指定できます。
+これらはどのページにでもあるからです。
+URLは"home.pl"のように、ページ名の部分だけでも構いません。
+
+ my =item get_main_menu("home.pl");
+
+URLを省略した時には、最後にデータ取得メソッドか、getまたはpostメソッドで取得したページになります。
+
+=over 4
+
+=item get_main_menu
+
+ページ先頭部のメインメニューを取得します。
+
+=item get_banner
+
+バナーを取得します。
+
+=item get_tool_bar
+
+メインメニューの下に標示されるツールバーを取得します。
+
+=back
+
+また、別の例外としてget_show_log_countはあしあと数を返します。
+同様に、get_self_idは自分のIDを返します。
+これらの返り値は配列でも、ハッシュリファレンスでもなく、単なるスカラです。
+
+ my $count = $mixi->get_show_log_count;
+ my $id = $mixi->get_self_id;
+
+=over 4
+
+=item get_show_log_count
+
+あしあとを取得します。
+
+=item get_self_id
+
+自分のIDを取得します。
+
+=back
+
+=head1 LWP::UserAgentスタイルでのアクセス
+
+ログインとデータ取得メソッドを使ったコーディングは簡単ですが、取得できるデータは限られますし、エラーハンドリングの弱さが泣き所です。
+もう少し細かい制御と自由な利用を考えるのであれば、これをLWP::UserAgentだと思って使ってみてください。
+
+実際に、WWW::MixiのスーパークラスはLWP::RobotUAで、さらにそのスーパークラスはLWP::UserAgentです。
+多くのメソッドがLWP::UserAgentから継承されており、それほど違いを感じることはないでしょう。
+
+=head2 ログイン
+
+LWP::UserAgentスタイルでコーディングするにしても、ログインはloginメソッドを使ってしまって良いでしょう。
+
+LWP::UserAgentを使う時のログイン作業は、POSTのHTTP::Requestオブジェクトを生成し、Cookieを有効にし、ログインページにアクセスするといった手順になります。
+ログインメソッドは、内部的には単にこれを順番に行います。
+その後はCookieでセッションIDが自動的に送受信されますので、LWP::UserAgentでするようにrequestやsimple_requestメソッドで各ページにアクセスできます。
+
+例えば、ログイン後にホームのHTML部分を出力するには以下のようにします。
+
+ use WWW::Mixi;
+ use HTTP::Request::Common;
+ 
+ my $mixi = WWW::Mixi->new('me****@mixi*****', 'mixi_password');
+ 
+ print "ログインします。\n";
+ my $response = $mixi->login;
+ 
+ print "ホームを取得します。\n";
+ $request = &HTTP::Request::Common::GET('http://mixi.jp/home.pl');
+ $response = $mixi->request($request);
+ print $response->content;
+
+=head2 getメソッド
+
+LWP::UserAgentモジュールでの標準的なページ取得は(1)HTTP::Requestオブジェクトの生成、(2)requestメソッドでリクエストの処理の手順になります。
+WWW::Mixiモジュールでは、この他にgetとpostという簡易的なメソッドを用意しており、これを使うこともできます。
+
+例えば、上では次の様にしてホームを取得しました。
+
+ use WWW::Mixi;
+ use HTTP::Request::Common;
+ 
+ (ç•¥)
+ 
+ print "ホームを取得します。\n";
+ $request = &HTTP::Request::Common::GET('http://mixi.jp/home.pl');
+ $response = $mixi->request($request);
+ print $response->content;
+
+getを使うと、HTTP::Request::Commonモジュールなどを使ったリクエストの生成をせずに、直接URLを指定すれば済みます。
+また、URLも'http://'から始まる絶対URLではなく、最後のファイル名(またはそこから拡張子の'.pl'を省いたもの)を指定すれば十分です。
+つまり、下のように書けば同じ事ができます。
+
+ use WWW::Mixi;
+ 
+ (ç•¥)
+ 
+ print "ホームを取得します。\n";
+ $response = $mixi->get('home.pl');
+ print $response->content;
+
+=head2 postメソッド
+
+簡単にGETでページを取得するためのメソッドとして、WWW::Mixiにはgetというメソッドが用意されていました。
+
+同様にPOSTでフォームの入力値を送信するには、postという簡易的なメソッドを使うことができます。
+postでは、URLの他にフォームデータを引数で渡します。
+例えば、次のようにすれば日記の投稿ができます。
+
+ use WWW::Mixi;
+ 
+ my %diary = (
+ 	'submit'      => 'confirm',                  # プレビュー:main、作成:confirm、修正:cancel
+ 	'diary_title' => 'WWW::Mixiで日記の投稿',
+ 	'diary_body'  => "WWW::Mixiモジュールで日記を投稿してみます。\nPOSTメソッドの試験です。",
+ 	'photo1'      => '',
+ 	'photo2'      => '',
+ 	'photo3'      => '',
+ );
+ 
+ my $mixi = WWW::Mixi->new('me****@mixi*****', 'mixi_password');
+ 
+ print "ログインします。\n";
+ my ($result, $response) = $mixi->login;
+ 
+ print "日記を投稿します。\n";
+ $response = $mixi->post('add_diary.pl', %diary);
+
+フォームの値は、送信前に自動的にエンコードされます。
+意識的にエンコードやエスケープをする必要はありません。
+
+=head2 ファイルの送信
+
+postメソッドでは写真など、ファイルを送信することも考慮されています(が、まったく試験されていません。ぜひ試験して、結果を教えてください)。
+
+例えば、日記のプレビューを表示するためのアクションでは、日記に貼付する写真を「photo1」「photo2」「photo3」の3つのフィールドに入れてやることができます。
+フィールド値にファイルを指定したい時は、ファイルパスだけを持つ配列リファレンスを指定します。
+
+ use WWW::Mixi;
+ 
+ my %diary = (
+ 	'submit'      => 'main',                  # プレビュー:main、作成:confirm、修正:cancel
+ 	'diary_title' => 'WWW::Mixiで日記の投稿',
+ 	'diary_body'  => "WWW::Mixiモジュールで日記を投稿してみます。\nPOSTメソッドの試験です。",
+ 	'photo1'      => ['c:\My Documents\photos\walrus.png'],
+ 	'photo2'      => '',
+ 	'photo3'      => '',
+ );
+ 
+ my $mixi = WWW::Mixi->new('me****@mixi*****', 'mixi_password');
+ 
+ print "ログインします。\n";
+ my ($result, $response) = $mixi->login;
+ 
+ print "日記を投稿します。\n";
+ $response = $mixi->post('add_diary.pl', %diary);
+
+=head2 メインメニューの解析メソッド
+
+コンテンツの取得が済めば、次は必要なデータを取り出すための解析をするでしょう。
+WWW::Mixiモジュールには、いくつかのページ用の解析メソッドがあります。
+
+解析系で一番簡単な(そして最初に作られた)解析メソッドがメインメニュー(ページ先頭のmixiのログと一緒に「ホーム」「検索」等のボタンが埋め込まれたメニューです)を解析するparse_main_menuメソッドです。
+このメソッドは、次のような配列のリファレンスを返します。
+
+ {
+ 	'subject' => 'ホーム',
+ 	'link' => 'http://mixi.jp/home.pl'
+ }
+
+例として、ホームを取得してメインメニューの各項目を出力するスクリプトを挙げましょう。
+ただしホームの取得までの部分は、「ページの取得」の項で出てきたものと同じなのでざっくり済ませています。
+
+ use WWW::Mixi;
+ 
+ my $mixi = WWW::Mixi->new('me****@mixi*****', 'mixi_password');
+ print "ログインします。\n";
+ my $response = $mixi->login;
+ print "ホームを取得します。\n";
+ $response = $mixi->get('home.pl');
+ 
+ print "メインメニューを出力します。\n";
+ my =item parse_main_menu($response);
+ foreach my $item (@items) {
+ 	my $subject = $item->{'subject'};
+ 	my $link = $item->{'link'};
+ 	print "$subject -> $link\n";
+ }
+
+なお、$responseを指定しなかった時は、最後にgetまたはpostメソッドで取得したデータを解析します(requestやsimple_requestは対象外です)。
+上の例では、解析しているのは最後にgetで取得したデータなので、下のように$responseの指定は省いても構いません。
+
+ my =item parse_main_menu();
+
+=head2 その他の解析メソッド
+
+メインメニュー用のparse_main_methodの他にも、いくつかの解析メソッドが設けられています。
+
+解析メソッドはいずれも$responseを引数に取り、ほとんどはハッシュリファレンスの配列を返します。
+$responseを指定しなかった時の解析対象は、最後にgetまたはpostメソッドで取得したデータです。
+ハッシュリファレンスの持つキー項目は、メソッドごとに違います。
+
+以下は0.21版で利用できる解析用メソッドの一覧です。
+最新版ではメソッドが追加されていたり変更されていたりするかも知れませんので、詳細はドキュメントを確認してください。
+
+=over 4
+
+=item parse_main_menu
+
+ページ先頭部のメインメニューを解析します。
+
+=item parse_banner
+
+メインメニューに埋め込まれているバナーを解析します。
+
+=item parse_tool_bar
+
+メインメニューの下に標示されるツールバーを解析します。
+
+=item parse_information
+
+ホーム(home.pl)に表示される「管理者からのお知らせ」を解析します。
+
+=item parse_calendar
+
+カレンダー(calendar.pl)上のイベント(参加イベント、不参加イベント、マイミクシィの誕生日)を解析します。
+
+=item parse_calendar_term
+
+カレンダー(calendar.pl)が表示している期間(年月)を解析します。
+
+=item parse_calendar_next
+
+カレンダー(calendar.pl)の「次の月」へのリンクを解析します。
+
+=item parse_calendar_previous
+
+カレンダー(calendar.pl)の「前の月」へのリンクを解析します。
+
+=item parse_list_bookmark
+
+お気に入り(list_bookmark.pl)を解析します。
+
+=item parse_list_comment
+
+最近のコメント(list_comment.pl)に表示される「最近のコメント一覧」を解析します。
+
+=item parse_list_community
+
+コミュニティ一覧(list_community.pl)に表示されるコミュニティを解析します。
+
+=item parse_list_community_next
+
+コミュニティ一覧(list_community.pl)の「次のページ」へのリンクを解析します。
+
+=item parse_list_community_previous
+
+コミュニティ一覧(list_community.pl)の「前のページ」へのリンクを解析します。
+
+=item parse_list_diary
+
+日記(list_diary.pl)の日記項目を解析します。
+
+=item parse_list_diary_next
+
+日記(list_diary.pl)の「次のxx件」へのリンクを解析します。
+
+=item parse_list_diary_previous
+
+日記(list_diary.pl)の「前のxx件」へのリンクを解析します。
+
+=item parse_list_friend
+
+友人・知人一覧(list_friend.pl)の友人・知人を解析します。
+
+=item parse_list_friend_next
+
+友人・知人一覧(list_friend.pl)の「次のページ」へのリンクを解析します。
+
+=item parse_list_friend_previous
+
+友人・知人一覧(list_friend.pl)の「前のページ」へのリンクを解析します。
+
+=item parse_list_message
+
+メッセージ(message.pl)に表示される「受信箱」を解析します。
+
+=item parse_new_bbs
+
+コミュニティ最新書き込み(new_bbs.pl)を解析します。
+
+=item parse_new_comment
+
+日記コメント記入履歴(new_comment.pl)を解析します。
+
+=item parse_new_friend_diary
+
+マイミクシイ最新日記(new_friend_diary.pl)を解析します。
+
+=item parse_new_friend_diary_next
+
+マイミクシィ最新日記(new_friend_diary.pl)の「次のページ」へのリンクを解析します。
+
+=item parse_new_friend_diary_previous
+
+マイミクシィ最新日記(new_friend_diary.pl)の「前のページ」へのリンクを解析します。
+
+=item parse_new_review
+
+マイミクシイ最新レビュー(new_review.pl)を解析します。
+
+=item parse_show_log
+
+あしあと(show_log.pl)を解析します。
+
+=item parse_show_log_count
+
+あしあと(show_log.pl)の「ページ全体のアクセス数」を解析します。
+このメソッドの返り値はアクセス数で、ハッシュリファレンスの配列ではありません。
+
+=item parse_add_diary_preview
+
+日記作成のプレビュー(add_diary.pl)を解析し、各ボタンに相当するフォームの値を返します。
+
+=item parse_self_id
+
+おすすめレビュー(list_review.pl)を解析し、自分のIDを返します。
+このメソッドの返り値はIDで、ハッシュリファレンスの配列ではありません。
+
+=back
+
+=head1 SEE ALSO
+
+L<WWW::Mixi>, L<LWP::UserAgent>, L<WWW::RobotUA>, L<HTTP::Request::Common>
+
+=head1 COPYRIGHT
+
+Copyright 2004-2004 TSUKAMOTO Makio.
+
+This text is free document; you can redistribute it and/or
+modify it under the same terms as Perl itself.
+
+=cut
Index: affelio/apps/Mixi/extlib/WWW/Mixi/Mixi.pod
diff -u /dev/null affelio/apps/Mixi/extlib/WWW/Mixi/Mixi.pod:1.1
--- /dev/null	Mon Aug 29 19:41:05 2005
+++ affelio/apps/Mixi/extlib/WWW/Mixi/Mixi.pod	Mon Aug 29 19:41:05 2005
@@ -0,0 +1,1612 @@
+=encoding utf8
+
+=head1 NAME
+
+WWW::Mixi - Mixiアクセス用のLWP::UserAgentモジュール
+
+=head1 SYNOPSIS
+
+  use WWW::Mixi;
+  $mixi = WWW::Mixi->new('me****@foo*****', 'password');
+  $mixi->login;
+  my $res = $mixi->get('home.pl');
+  print $res->content;
+
+=head1 DESCRIPTION
+
+Mixiにアクセスするためのモジュールです。
+
+LWP::RobotUAのサブクラスになっており、LWP::UserAgentおよびLWP::RobotUAと同じように使うことができます。
+WWW::MixiにはLWP::UserAgentより便利な点が3つあります。
+
+まず、WWW::Mixiではログイン関連の作業をすべてloginメソッドで済ませることができます。
+loginメソッドは、Cookieが無効になっていれば有効にし、オブジェクト生成時に受け取ったメールアドレスとパスワードをloginページに送出し、レスポンスを解析してセッションIDとリフレッシュ先のURLを取得します。
+ログイン状況は、is_login_required、is_logined、session、refreshなどのメソッドで確認できます。
+
+それから、いくつかの便利なメソッドが用意されています。
+大別すれば2系統で、一つは絶対URLを取得するためのabsolute_urlやabsolute_linked_urlです。前者はmixiのホームページまたは指定されたURLをベースとした絶対URLを、後者は最後にgetまたはpostで取得したページをベースとしたURLを返します。
+もう一つは、mixiのコンテンツを解析するためのメソッドです。メインメニュー解析用のparse_main_menu、ツールバー解析用のparse_tool_bar、お知らせ解析用のparse_informationメソッドなど多数の解析メソッドと、URLの取得と解析をまとめて行うget_main_menuなどのメソッドがあります。
+
+また、実際にはLWP::RobotUAのサブクラスなので、ロボットとしての妥当な動作を行おうとします。
+一つには、また、サーバーに高負荷をかけないようdelayが1秒に設定されており、1秒間に1回以上のリクエストは処理しないようになっています。
+なお、tobot.txtのチェックはしていません。
+いくつかの経緯から、WWW::Mixiではrobot.txtをチェックしないことをMixi運営事務局から提案されたことによります。
+
+=head1 METHODS
+
+WWW::MixiはLWP::RobotUAのサブクラスとして実装されていますので、LWP::RobotUAとその親クラスであるLWP::UserAgentのメソッドを引き継いでいます。
+これらの使い方については、各クラスのドキュメントをご覧ください。
+
+=head2 Constructor
+
+WWW::Mixiのコンストラクタです。
+
+=head3 $mixi = WWW::Mixi->new($email [, $password] [, '-log' => \&logging_method] [, '-abort' => \&aborting_method] [, '-rewrite' => \&rewriting_method] )
+
+WWW::Mixiオブジェクトを作成するコンストラクタです。
+
+最初に引数は、mixiにログインするためのメールアドレスで、必須です。
+二番目の引数は、mixiにログインするためのパスワードです。
+'-log'はオプションで、ログを出力するためのメソッドを指定します。
+'-abort'はオプションで、エラー時の終了処理を行うためのメソッドを指定します。
+'-rewrite'はオプションで、解析時のテキスト値のリフォーマットをするためのメソッドを指定します。
+
+このメソッドはLWP::RobotUA(を介してLWP::UserAgent)から継承したnewメソッドを上書きしています。
+
+=head2 Login and Login information
+
+mixiにログインするためのメソッドと、現在のログイン状況、セッションIDなどの関連情報を取得するためのメソッド群です。
+
+=head3 $response = $mixi->login( [$password] );
+
+mixiにログインします。
+必要であれば、Cookieの有効化などが行われます。
+
+ログイン時のパスワードは、$passwordが指定されればこの値を使用します。
+未指定時は、コンストラクタで指定されたパスワードを使用します。
+コンストラクタでもパスワードを指定していない場合、このメソッドは何のアクションも行わず、undefを返します。
+
+返り値はログイン時のHTTP::Responseオブジェクトです。
+ログイン失敗時のレスポンスコードは401になりますので、以下のようなエラーハンドリングが可能です。
+
+ $mixi->login->is_sucess or die 'Login failed';
+
+次のようにすれば、ログイン失敗時に理由を確認しやすくなるでしょう。
+
+ $res = $mixi->login;
+ $res->is_success or die $res->status_line;
+
+=head3 $result = $mixi->is_logined
+
+ログイン済みであれば1、未ログインであれば0を返します。
+
+=head3 $result = $mixi->is_login_required( [$response] )
+
+最後にgetまたはpostで取得したページデータを解析して、ログインフォームが表示されていないか確認します。
+ページの取得が成功していて、ログインフォームが表示されていないときには0を返します。
+ログインフォームが表示されているときなどには、エラーメッセージを返します。
+
+$responseを指定したときには、最後に取得したページの変わりに$responseを解析します。
+$responseにはHTTP::Responseオブジェクト(get、post、request、simple_requestメソッドなどの返り値がそうです)を指定してください。
+
+=head3 $session = $mixi->session( [$session] );
+
+現在のセッションIDを返します。
+ログイン前など、セッションIDを取得できていない時にはundefが返ります。
+
+$sessionを指定したときには、セッションIDを指定した値で置き換えます。
+
+=head3 $session = $mixi->stamp( [$stamp] );
+
+現在のセッションスタンプを返します。
+ログイン前など、セッションスタンプを取得できていない時にはundefが返ります。
+
+$stampを指定したときには、セッションスタンプを指定した値で置き換えます。
+
+=head3 $session = $mixi->refresh
+
+ログイン時に取得したリフレッシュURLを返します。
+
+=head2 Fetch URL
+
+ページを取得するためのメソッドです。
+なお、ログイン前に実行した場合は、該当ページのコンテンツは取得できず、レスポンスコードは401になります。
+
+=head3 $response = $mixi->request($request, $arg [, $size]) )
+
+このメソッドはLWP::UserAgentのrequestメソッドとほぼ同じ動作をします。
+使い方については、LWP::UserAgentのドキュメントを参照してください。
+
+なお、「データはありません。」が返された時のレスポンスコードは400、要ログイン時のレスポンスコードはloginメソッド同様401です。
+また、このメソッドはLWP::RobotUAのrequestメソッドを実行しています。
+例えばRobot exclutionを守る、指定されたアクセス間隔をあけるなどといった点は同様の動作をします。
+
+=head3 $response = $mixi->get($url)
+
+GETメソッドで指定されたURLを取得します。
+URLの代わりに'login'、'show_logs'などの'.pl'を省いたファイル名を指定しても構いません。
+
+返り値はHTTP::Responseオブジェクトで、これはLWP::UserAgentモジュールのrequestメソッドと同じです。
+
+=head3 $response = $mixi->post($url ['field' => value, ...])
+
+POSTメソッドで指定されたURLを取得します。
+URLの代わりに'login'、'show_logs'などの'.pl'を省いたファイル名を指定しても構いません。
+
+POST時のフィールドの値は、'name' => 'Mr. Mixi', 'Age' => '3years'のように、フィールド名と値の対で指定してください。この対はいくつ指定しても構いません。
+フィールド値にはファイルを指定することもできます。この時は、'pic1' => ['./picture.jpg']のように、ファイルパスだけを配列リファレンスで渡してください。
+なお、POSTデータはHTTP::Request::CommonモジュールのPOSTメソッドで処理されます。ファイル指定の詳細などについてはこちらでご確認ください。
+
+返り値はHTTP::Responseオブジェクトで、これはLWP::UserAgentモジュールのrequestメソッドと同じです。
+
+=head3 $response = $mixi->response()
+
+最後に取得されたレスポンスを返します。
+返り値はHTTP::Responseオブジェクトで、これはLWP::UserAgentモジュールのrequestメソッドの返り値と同じです。
+
+=head2 Parse response
+
+取得済みのページを解析します。
+
+解析系のメソッドはいずれも、引数$responseを指定したときには$responseを、未指定時は最後にgetまたはpostメソッドで取得したデータを解析します。
+$responseにはHTTP::Responseオブジェクト(get、post、request、simple_requestメソッドなどの返り値がそうです)を指定してください。
+
+=head3 @items = $mixi->parse_main_menu( [$response] );
+
+メインメニュー(「mixi」のロゴと一体になっている部分のメニュー)の項目を取得します。
+返り値は、項目ごとに以下のようなハッシュリファレンスにしたものの配列です。
+
+ {
+ 	'subject' => 'ホーム',
+ 	'link' => 'http://mixi.jp/home.pl'
+ }
+
+=head3 @items = $mixi->parse_banner( [$response] );
+
+バナー(メインメニューに埋め込まれているもの)を取得します。
+返り値は、項目ごとに以下のようなハッシュリファレンスにしたものの配列です。
+
+ {
+ 	'subject' => '求人サイトFind Job !',
+ 	'link' => 'http://mixi.jp/banner.pl?id=x'
+ 	'image' => 'http://banner.host.domain/image.gif'
+ }
+
+mixiの利用規約の「2.禁止事項」第二条には「mixi の運営またはネットワーク・システムを妨害する行為」が含まれており、バナーによる利益を得ることはmixiの運営に必要なことだと思われます。
+WWW::Mixiモジュールを使用する際は、上記を良く考慮した上で、バナーを適切に扱うことを推奨します。
+
+=head3 @items = $mixi->parse_tool_bar( [$response] );
+
+ツールバーの項目を取得します。
+返り値は、項目ごとに以下のようなハッシュリファレンスにしたものの配列です。
+
+ {
+ 	'subject' => 'トップページ',
+ 	'link' => 'http://mixi.jp/home.pl'
+ }
+
+=head3 @items = $mixi->parse_information( [$response] );
+
+お知らせの項目を取得します。
+返り値は、項目ごとに以下のようなハッシュリファレンスにしたものの配列です。
+
+ {
+ 	'subject' => 'あなたの友人を mixi に招待しよう!',
+ 	'link' => 'http://mixi.jp/invite.pl',
+ 	'description\' => '友人を招待'
+ }
+
+=head3 @items = $mixi->parse_calendar( [$response] );
+
+カレンダー(calendar.plのメイン部)を解析します。
+返り値は、項目ごとに以下のようなハッシュリファレンスにしたものの配列です。
+
+ {
+ 	'subject' => '誕生日',
+ 	'link' => 'http://mixi.jp/view_diary.pl?id=xxxxxx',
+ 	'name' => '塚本牧生',
+ 	'time' => '2004/08/18'
+ 	'icon' => 'http://mixi.jp/img/i_bd.gif'
+ }
+
+=head3 $item = $mixi->parse_calendar_term( [$response] );
+
+カレンダー(calendar.plのメイン部)の期間(年月)を解析します。
+返り値は、以下のようなハッシュリファレンスです。
+
+ {
+ 	'year' => '2004',
+ 	'month' => '8'
+ }
+
+=head3 $item = $mixi->parse_calendar_next( [$response] );
+
+カレンダー(calendar.plのメイン部)の「次の月」へのリンクを解析します。
+返り値は、「次の月」がある場合は以下のようなハッシュリファレンスです。
+
+ {
+ 	'subject' => '次の月',
+ 	'link' => 'http://mixi.jp/calendar.pl?year=2004&month=10&pref_id=13',
+ }
+
+=head3 $item = $mixi->parse_calendar_previous( [$response] );
+
+カレンダー(calendar.plのメイン部)の「前の月」へのリンクを解析します。
+返り値は、「前の月」がある場合は以下のようなハッシュリファレンスです。
+
+ {
+ 	'subject' => '前の月',
+ 	'link' => 'http://mixi.jp/calendar.pl?year=2004&month=10&pref_id=13',
+ }
+
+=head3 @items = $mixi->parse_list_bookmark( [$response] );
+
+お気に入り(list_bookmark.plのメイン部)を解析します。
+返り値は、項目ごとに以下のようなハッシュリファレンスにしたものの配列です。
+
+ {
+ 	'subject' => 'walrus',
+ 	'gender' => '男性',
+ 	'description' => 'PerlマニアでPDAマニアでザウルスユーザー。メインサイトの日記はこちらです。...',
+ 	'image' => 'http://img.mixi.jp/photo/member/xx/xx/xxxx.jpg',
+ 	'link' => 'http://mixi.jp/show_friend.pl?id=xxxxxx',
+ 	'time' => '2004/08/18 13:18'
+ }
+
+=head3 @items = $mixi->parse_list_comment( [$response] );
+
+最近のコメント(list_comment.plのメイン部)を解析します。
+返り値は、項目ごとに以下のようなハッシュリファレンスにしたものの配列です。
+
+ {
+ 	'subject' => 'こんにちわ。',
+ 	'link' => 'http://mixi.jp/view_diary.pl?id=xxxxxx',
+ 	'name' => '塚本牧生',
+ 	'time' => '2004/08/18 13:18'
+ }
+
+=head3 @items = $mixi->parse_list_community( [$response] );
+
+コミュニティ一覧(list_community.plのメイン部)を解析します。
+返り値は、項目ごとに以下のようなハッシュリファレンスにしたものの配列です。
+
+ {
+ 	'subject' => 'WWW::Mixiモジュール',
+ 	'link' => 'http://mixi.jp/view_community.pl?id=xxxx',
+ 	'image' => 'http://img.mixi.jp/photo/comm/xx/xx/xxxx_xxs.jpg',
+ 	'count' => '20'
+ }
+
+=head3 $item = $mixi->parse_list_community_next( [$response] );
+
+コミュニティ一覧(list_community.plのメイン部)の「次のページ」へのリンクを解析します。
+返り値は、「次のページ」がある場合は以下のようなハッシュリファレンスです。
+
+ {
+ 	'subject' => '次のxx件',
+ 	'link' => 'http://mixi.jp/list_community.pl?page=x',
+ }
+
+=head3 $item = $mixi->parse_list_community_previous( [$response] );
+
+コミュニティ一覧(list_community.plのメイン部)の「前のページ」へのリンクを解析します。
+返り値は、「前のページ」がある場合は以下のようなハッシュリファレンスです。
+
+ {
+ 	'subject' => '前の50件',
+ 	'link' => 'http://mixi.jp/list_community.pl?page=x',
+ }
+
+=head3 @items = $mixi->parse_list_diary( [$response] );
+
+日記(list_diary.pl)のメイン部分用の解析メソッドです。
+返り値は、項目ごとに以下のようなハッシュリファレンスにしたものの配列です。
+imagesの中身はサムネイルと本体画像のURLをハッシュリファレンスにしたものの配列になります。
+
+ {
+ 	'subject'     => 'こんにちは。',
+ 	'link'        => 'http://mixi.jp/view_diary.pl?id=xxxxxx',
+ 	'description' => '本文の冒頭...',
+ 	'time'        => '08/18 13:18'
+ 	'count'       => 'コメント件数',
+ 	'images'      => [
+ 		{
+ 			'link'        => 'http://img.mixi.jp/photo/diary/xx/xx/xxxxxxxxx_xxx.jpg',
+ 			'thumb_link'  => 'http://img.mixi.jp/photo/diary/xx/xx/xxxxxxxxx_xxxs.jpg'
+ 		}
+ 	]
+ }
+
+=head3 $item = $mixi->parse_list_diary_capasity( [$response] );
+
+日記(list_diary.plのメイン部)の「日記の使用状況」を解析します。
+返り値は、「日記の使用状況」がある場合は以下のようなハッシュリファレンスです。
+
+ {
+ 	'max' => '100.0',
+ 	'used' => '2.2',
+ }
+
+=head3 $item = $mixi->parse_list_diary_next( [$response] );
+
+日記(list_diary.plのメイン部)の「次のxx件」へのリンクを解析します。
+返り値は、「次のxx件」がある場合は以下のようなハッシュリファレンスです。
+
+ {
+ 	'subject' => '次のxx件',
+ 	'link' => 'http://mixi.jp/list_diary.pl?page=x',
+ }
+
+=head3 $item = $mixi->parse_list_diary_previous( [$response] );
+
+日記(list_diary.plのメイン部)の「前のxx件」へのリンクを解析します。
+返り値は、「前のxx件」がある場合は以下のようなハッシュリファレンスです。
+
+ {
+ 	'subject' => '前のxx件',
+ 	'link' => 'http://mixi.jp/list_diary.pl?page=x',
+ }
+
+=head3 @items = $mixi->parse_list_diary_monthy_menu( [$response] );
+
+日記(list_diary.pl)の各月のインデックスへのリンクを解析します。
+返り値は、月ごとに以下のようなハッシュリファレンスにしたものの配列です。
+
+ {
+ 	'link' => 'http://mixi.jp/list_diary.pl?year=2005&month=7',
+ 	'month' => '7',
+ 	'year' => '2005'
+ },
+
+=head3 @items = $mixi->parse_list_friend( [$response] );
+
+友人・知人一覧(list_friend.plのメイン部)を解析します。
+返り値は、項目ごとに以下のようなハッシュリファレンスにしたものの配列です。
+
+ {
+ 	'subject' => 'walrusさん',
+ 	'link' => 'http://mixi.jp/show_friend.pl?id=xxxxx',
+ 	'image' => 'http://img.mixi.jp/photo/member/xx/xx/xxxxx_xxxxxxxxxx.jpg',
+ 	'background' => 'http://img.mixi.jp/img/bg_xxx.gif',
+ 	'id' => 'xxxxx',
+ 	'count' => 'xxx'
+ 	'status' => '1時間以内',
+ }
+
+=head3 $item = $mixi->parse_list_friend_next( [$response] );
+
+友人・知人一覧(list_friend.plのメイン部)の「次のページ」へのリンクを解析します。
+返り値は、「次のページ」がある場合は以下のようなハッシュリファレンスです。
+
+ {
+ 	'subject' => '次のxx件',
+ 	'link' => 'http://mixi.jp/list_friend.pl?page=x',
+ }
+
+=head3 $item = $mixi->parse_list_friend_previous( [$response] );
+
+友人・知人一覧(list_friend.plのメイン部)の「前のページ」へのリンクを解析します。
+返り値は、「前のページ」がある場合は以下のようなハッシュリファレンスです。
+
+ {
+ 	'subject' => '前の50件',
+ 	'link' => 'http://mixi.jp/list_friend.pl?page=x',
+ }
+
+=head3 @items = $mixi->parse_list_message( [$response] );
+
+最近の受信メッセージ(list_message.plのメイン部)を解析します。
+返り値は、項目ごとに以下のようなハッシュリファレンスにしたものの配列です。
+statusはnew(新着)、opened(既読)、replied(返信済み)、unknown(不明)になります。
+
+ {
+ 	'subject' => 'こんにちわ。',
+ 	'link' => 'http://mixi.jp/view_message.pl?id=xxxxxx&box=xxxxx',
+ 	'name' => '塚本牧生',
+ 	'time' => '08/18',
+ 	'status' => 'replied',
+ 	'emvelope' => 'http://mixi.jp/img/mail5.gif'
+ }
+
+=head3 @items = $mixi->parse_list_outbox( [$response] );
+
+最近の送信メッセージ(list_message.pl?box=outboxのメイン部)を解析します。
+返り値は、項目ごとに以下のようなハッシュリファレンスにしたものの配列です。
+
+ {
+ 	'subject' => 'こんにちわ。',
+ 	'link' => 'http://mixi.jp/view_message.pl?id=xxxxxx&box=xxxxx',
+ 	'name' => '塚本牧生',
+ 	'time' => '08/18',
+ }
+
+=head3 @items = $mixi->parse_new_album( [$response] );
+
+マイミクシィ最新アルバム(new_album.plのメイン部)を解析します。
+返り値は、項目ごとに以下のようなハッシュリファレンスにしたものの配列です。
+
+ {
+ 	'subject' => '塚本家の人々',
+ 	'link' => 'http://mixi.jp/view_album.pl?id=xxxxxx',
+ 	'name' => '塚本牧生',
+ 	'time' => '2004/08/18 13:18'
+ }
+
+=head3 @items = $mixi->parse_new_bbs( [$response] );
+
+コミュニティ最新書き込み(new_bbs.plのメイン部)を解析します。
+返り値は、項目ごとに以下のようなハッシュリファレンスにしたものの配列です。
+
+ {
+ 	'subject' => 'こんにちわ。',
+ 	'link' => 'http://mixi.jp/view_bbs.pl?id=xxxxxx',
+ 	'name' => '塚本牧生',
+ 	'time' => '2004/08/18 13:18'
+ }
+
+=head3 $item = $mixi->parse_new_friend_diary_next( [$response] );
+
+コミュニティ最新書き込み(new_bbs.plのメイン部)の「次のページ」へのリンクを解析します。
+返り値は、「次のページ」がある場合は以下のようなハッシュリファレンスです。
+
+ {
+ 	'subject' => '次のxx件を表示',
+ 	'link' => 'http://mixi.jp/new_friend_diary.pl?page=x',
+ }
+
+=head3 $item = $mixi->parse_new_friend_diary_previous( [$response] );
+
+コミュニティ最新書き込み(new_bbs.plのメイン部)の「前のページ」へのリンクを解析します。
+返り値は、「前のページ」がある場合は以下のようなハッシュリファレンスです。
+
+ {
+ 	'subject' => '前の50件を表示',
+ 	'link' => 'http://mixi.jp/new_friend_diary.pl?page=x',
+ }
+
+=head3 @items = $mixi->parse_new_comment( [$response] );
+
+日記コメント記入履歴(new_comment.plのメイン部)を解析します。
+返り値は、項目ごとに以下のようなハッシュリファレンスにしたものの配列です。
+
+ {
+ 	'subject' => 'こんにちわ。',
+ 	'link' => 'http://mixi.jp/view_diary.pl?id=xxxxxx',
+ 	'name' => '塚本牧生',
+ 	'time' => '2004/08/18 13:18'
+ }
+
+=head3 @items = $mixi->parse_new_diary( [$response] );
+
+新着日記検索(new_diary.plのメイン部)を解析します。
+返り値は、項目ごとに以下のようなハッシュリファレンスにしたものの配列です。
+
+ {
+ 	'subject' => 'こんにちわ。',
+ 	'description' => 'mixiはじめました。皆様、よろしくお願いしま',
+ 	'time' => '2005/05/20 13:32'
+ 	'name' => '塚本牧生',
+ 	'gender' => '男性',
+ 	'link' => 'http://mixi.jp/view_diary.pl?id=xxxxxx&owner_id=xxxxx',
+ 	'image' => 'http://img.mixi.jp/photo/member/xx/xx/xxxxx_xxxxxxxxs.jpg',
+ }
+
+=head3 $item = $mixi->parse_new_diary_next( [$response] );
+
+新着日記検索(new_diary.plのメイン部)の「次のページ」へのリンクを解析します。
+返り値は、「次を表示」がある場合は以下のようなハッシュリファレンスです。
+
+ {
+ 	'subject' => '次を表示',
+ 	'link' => 'http://mixi.jp/new_diary.pl?page=2&keyword=xx'
+ }
+
+=head3 $item = $mixi->parse_new_diary_previous( [$response] );
+
+新着日記検索(new_diary.plのメイン部)の「前のページ」へのリンクを解析します。
+返り値は、「前を表示」がある場合は以下のようなハッシュリファレンスです。
+
+ {
+ 	'subject' => '前を表示',
+ 	'link' => 'http://mixi.jp/new_diary.pl?page=2&keyword=xx'
+ }
+
+=head3 @items = $mixi->parse_new_friend_diary( [$response] );
+
+マイミクシィ最新日記(new_friend_diary.plのメイン部)を解析します。
+返り値は、項目ごとに以下のようなハッシュリファレンスにしたものの配列です。
+
+ {
+ 	'subject' => 'こんにちわ。',
+ 	'link' => 'http://mixi.jp/view_diary.pl?id=xxxxxx',
+ 	'name' => '塚本牧生',
+ 	'time' => '2004/08/18 13:18'
+ }
+
+=head3 $item = $mixi->parse_new_friend_diary_next( [$response] );
+
+マイミクシィ最新日記(new_friend_diary.plのメイン部)の「次のページ」へのリンクを解析します。
+返り値は、「次のページ」がある場合は以下のようなハッシュリファレンスです。
+
+ {
+ 	'subject' => '次のxx件を表示',
+ 	'link' => 'http://mixi.jp/new_friend_diary.pl?page=x',
+ }
+
+=head3 $item = $mixi->parse_new_friend_diary_previous( [$response] );
+
+マイミクシィ最新日記(new_friend_diary.plのメイン部)の「前のページ」へのリンクを解析します。
+返り値は、「前のページ」がある場合は以下のようなハッシュリファレンスです。
+
+ {
+ 	'subject' => '前の50件を表示',
+ 	'link' => 'http://mixi.jp/new_friend_diary.pl?page=x',
+ }
+
+=head3 @items = $mixi->parse_new_review( [$response] );
+
+マイミクシィ最新レビュー(new_review.plのメイン部)を解析します。
+返り値は、項目ごとに以下のようなハッシュリファレンスにしたものの配列です。
+
+ {
+ 	'subject' => 'mixiの本。',
+ 	'link' => 'http://mixi.jp/list_item_review.pl?reviewer_id=xxxx&item_id=xxxxx',
+ 	'name' => '塚本牧生',
+ 	'time' => '2004/08/18 13:18'
+ }
+
+=head3 $id = $mixi->parse_self_id( [$response] );
+
+プロフィール(show_profile.pl)を解析し、自分のIDを返します。
+IDを取得できなかった時の返り値は0です。
+
+このメソッドは他の多くの解析系メソッドと違い、ハッシュリファレンスの配列ではなくただの文字列(スカラ値)を返すことに注意してください。
+
+=head3 $item = $mixi->parse_show_friend_outline( [$response] );
+
+ニックネームや写真(show_friend.plのプロフィール画像左上部)を解析します。
+返り値は、以下のようなハッシュリファレンスです。
+
+ {
+ 	'name' => 'まきお',
+ 	'link' => 'http://mixi.jp/show_friend.pl?id=xxx',
+ 	'image' => 'http://img.mixi.jp/photo/member/xx/xx/xxx_xxxxxxxxxx.jpg',
+ 	'description' => '最終ログインは5時間以内',
+ 	'count' => 20,
+ 	'step' => 2,
+ 	'relation' => {
+ 		'link' => 'http://mixi.jp/show_friend.pl?id=xxx',
+ 		'name' => 'walrus'
+ 	}
+ }
+
+stepはマイミクシィの場合1、マイミクシィのマイミクシィの場合2、どちらでもない場合0です。
+stepが2の時は上のように、間に挟まるマイミクシィの情報がrelationにセットされます。
+
+=head3 $item = $mixi->parse_show_friend_profile( [$response] );
+
+プロフィール(show_friend.plのメイン部)を解析し、プロフィールを返します。
+返り値は、以下のようなハッシュリファレンスです。
+
+ {
+ 	'現住所' => '東京都高坂区',
+ 	'好きな映画' => 'ジャッカルの日',
+ 	'所属' => '株式会社タカサカク',
+ 	'出身地' => '埼玉県坂槻市',
+ 	'å¹´é½¢' => '30æ­³',
+ 	'名前' => '塚本 牧生 (男性)',
+ 	'血液型' => 'O型',
+ 	'職業' => 'プログラマ',
+ 	'趣味' => '映画鑑賞, 読書',
+ 	'好きな本・マンガ' => '薔薇の名前',
+ 	'誕生日' => '01月01日',
+ 	'自己紹介' => 'こんにちはー。'
+ }
+
+ハッシュの項目は、その人の公開しているプロフィールの内容によって増減します。
+
+=head3 @items = $mixi->parse_show_log( [$response] );
+
+あしあと(show_log.plのメイン部)を解析し、あしあとを返します。
+返り値は、項目ごとに以下のようなハッシュリファレンスにしたものの配列です。
+
+ {
+ 	'link' => 'http://mixi.jp/show_friend.pl?id=xxxxx',
+ 	'name' => '塚本牧生',
+ 	'time' => '2004/08/18 13:18'
+ }
+
+=head3 $count = $mixi->parse_show_log_count( [$response] );
+
+あしあと(show_log.plのメイン部)を解析し、あしあと数を返します。
+
+このメソッドは他の多くの解析系メソッドと違い、ハッシュリファレンスの配列ではなくただの数値(スカラ値)を返すことに注意してください。
+
+=head3 $item = $mixi->parse_view_diary( [$response] );
+
+日記(view_diary.plのメイン部)を解析します。
+返り値は、以下のようなハッシュリファレンスです。
+
+ {
+ 	'subject'     => 'こんにちは。',
+ 	'link'        => 'http://mixi.jp/view_diary.pl?id=xxxxxx',
+ 	'description' => '本文',
+ 	'time'        => '2005/05/24 22:36'
+ 	'images'      => [
+ 		{
+ 			'link'        => 'http://img.mixi.jp/photo/diary/xx/xx/xxxxxxxxx_xxx.jpg',
+ 			'thumb_link'  => 'http://img.mixi.jp/photo/diary/xx/xx/xxxxxxxxx_xxxs.jpg'
+ 		}
+ 	]
+ 	'comments'    => [
+ 		{
+ 			'link' => 'http://mixi.jp/show_friend.pl?id=xxxxxx',
+ 			'time' => '2005/05/24 22:56',
+ 			'name' => 'コメンター',
+ 			'description' => 'こんにちは~。'
+ 		},
+ 	]
+ }
+
+images、commentsは0件の時も、複数件の時もあることに注意してください。
+
+=head3 $item = $mixi->parse_view_message( [$response] );
+
+受信メッセージ(view_message.plのメイン部)のメッセージを解析します。
+返り値は、メッセージを取得できたときは以下のようなハッシュリファレンスです。
+
+送信メッセージにも対応しました。
+
+ {
+ 	'subject'     => 'こんにちわ。',
+ 	'image'       => 'http://img.mixi.jp/photo/member/xx/xx/xxxxxx_xxxxxxxxs.jpg',
+ 	'link'        => 'http://mixi.jp/show_friend.pl?id=?id=xxxxxx',
+ 	'name'        => '塚本牧生',
+ 	'time'        => '2004/08/18 12:34',
+ 	'description' => '本文...',
+ }
+
+=head3 @items = $mixi->parse_view_message_form( [$response] );
+
+受信メッセージ(view_message.plのメイン部)のメッセージ削除、返信などのフォームを解析します。
+返り値は、フォームごとに以下のようなハッシュリファレンスにしたものの配列です。
+
+ {
+ 	'command' => 'delete_message'
+ 	'action' => 'http://mixi.jp/delete_message.pl?box=xxxxx&message_id=xxxxxxx',
+ 	'submit' => '削 除',
+ }
+
+各フォームは、actionに対応する値のURLに対して、フォーム項目submitとしてsubmitに対応する値だけをpostで送信するものです。
+
+=head3 @items = $mixi->parse_add_diary_preview( [$response ]);
+
+日記作成のプレビュー(add_diary.plのメイン部)を解析し、各ボタンに相当するフォームの値を返します。
+返り値は、フォームごとに以下のようなハッシュリファレンスにしたものの配列です。
+
+ {
+ 	'__action__' => 'http://mixi.jp/show_friend.pl?id=xxxxx',
+ 	'submit' => 'confirm',
+ 	'diary_title' => '今日の日記',
+ 	'diary_body' => '今日は朝から晩だった。
+ 生まれたばかりの...',
+ 	'packed' => 'asjkEKJHFu.16190.diary:1:adjksHfsdk.16190.diary_s:1',
+ 	'post_key' => '012a34b56cd78e901fa23b45678cde90',
+ }
+
+__action__というキーがあることに注意してください。
+これはこのフォームの送信先URLを表しているもので、フォーム値ではありません。
+日記を作成する(confirm)する時には、このキーは削除しておく必要があります。
+
+'post_key'は自動的にmixi側からランダムな文字列が返されます。
+また、'packed'はプレビュー取得時に画像ファイルをおくっていれば、同じくmixi側からランダムな文字列が返されます。
+日記を投稿する(postまたはget_edit_diary_confirm)際にはプレビューで取得したこれらの値も必要です。
+
+=head3 $item = $mixi->parse_add_diary_confirm( [$response ]);
+
+日記作成結果(add_diary.plのメイン部)を解析します。
+返り値は、以下のようなハッシュリファレンスです。
+
+ {
+ 	'link' => 'http://mixi.jp/list_diary.pl',
+ 	'subject' => '作成が完了しました。反映に時間がかかることがありますので、表示されていない場合は少々お待ちください。',
+ 	'result' => 1
+ }
+
+なお、コンテンツに「作成が完了しました。」のメッセージが見つからない時は、返り値はありません。
+また、レスポンスが「データはありません。」だった時にも、返り値はありません。
+どちらの場合も、おそらくメッセージ送信は失敗しています。
+返り値がなかった場合、レスポンスコードが200であればレスポンスのコンテンツを、400であればレスポンスメッセージをチェックしてみてください。
+
+=head3 @items = $mixi->parse_delete_diary_preview( [$response ]);
+
+日記削除のプレビュー(delete_diary.plのメイン部)を解析し、各ボタンに相当するフォームの値を返します。
+返り値は、フォームごとに以下のようなハッシュリファレンスにしたものの配列です。
+
+ {
+ 	'__action__' => 'http://mixi.jp/delete_dairy.pl?id=xxxxx',
+ 	'submit' => 'confirm',
+ }
+
+__action__というキーがあることに注意してください。
+これはこのフォームの送信先URLを表しているもので、フォーム値ではありません。
+日記を削除する(confirm)する時には、このキーは削除しておく必要があります。
+
+=head3 $item = $mixi->parse_delete_diary_confirm( [$response ]);
+
+日記削除結果(delete_diary.plのメイン部)を解析します。
+日記の削除は成功時、レスポンスコード302によって日記(list_diary.pl)にリダイレクトされますので、解析結果はparse_list_diaryメソッドと同じになります。
+
+返り値がなかったときは、レスポンスコードと、レスポンスのpreviousメソッドで取得できるリダイレクトの履歴およびその際のレスポンスコードをチェックしてみてください。
+
+=head3 @items = $mixi->parse_edit_diary_preview( [$response ]);
+
+日記編集のプレビュー(edit_diary.plのメイン部)を解析し、各フォームの値を返します。
+返り値は、フォームごとに以下のようなハッシュリファレンスにしたものの配列です。
+
+ {
+ 	'__action__' => 'http://mixi.jp/edit_diary.pl?id=xxxxx',
+ 	'submit' => 'main',
+ 	'diary_title' => '今日の日記',
+ 	'diary_body' => '今日は朝から晩だった。
+ 生まれたばかりの...',
+ 	'form_date' => 'date',
+ 	'photo1' => '',
+ 	'photo2' => '',
+ 	'photo3' => '',
+ }
+
+__action__というキーがあることに注意してください。
+これはこのフォームの送信先URLを表しているもので、フォーム値ではありません。
+編集内容を確定する時には、このキーは削除しておく必要があります。
+
+=head3 @items = $mixi->parse_edit_diary_image( [$response ]);
+
+日記編集のプレビュー(edit_diary.plのメイン部)を解析します。
+返り値は、フォームごとに以下のようなハッシュリファレンスにしたものの配列です。
+
+ {
+ 	'thumb_link' => 'http://img1.mixi.jp/photo/diary/xx/xx/xxxxx_xxxs.jpg',
+ 	'subject' => '写真1',
+ 	'link' => 'http://mixi.jp/delete_diary_photo.pl?diary_id=xxxxx&photo_number=xxx'
+ }
+
+'link'に対応するURLは、この写真を削除するためのものです。
+
+=head3 $item = $mixi->parse_edit_diary_confirm( [$response ]);
+
+日記編集結果(edit_diary.plのメイン部)を解析します。
+日記の編集は成功時、レスポンスコード302によって日記(list_diary.pl)にリダイレクトされますので、解析結果はparse_list_diaryメソッドと同じになります。
+
+返り値がなかったときは、レスポンスコードと、レスポンスのpreviousメソッドで取得できるリダイレクトの履歴およびその際のレスポンスコードをチェックしてみてください。
+
+=head3 $item = $mixi->parse_send_message_preview( [$response ]);
+
+メッセージ送信のプレビュー(send_message.plのメイン部)を解析し、フォームデータを返します。
+返り値は以下のようなハッシュリファレンスです。
+
+ {
+ 	'__action__' => 'http://mixi.jp/send_message.pl?id=267049',
+ 	'subject' => '今日の手紙。',
+ 	'body' => '今日は朝から晩だった。
+ 生まれたばかりの...',
+ 	'submit' => 'confirm',
+ 	'yes' => ' 送 信 ',
+ 	'no' => ' 修  正 ',
+ 	'post_key' => '777c74e88ba28b909be01d31082daa67',
+ }
+
+__action__というキーがあることに注意してください。
+これはこのフォームの送信先URLを表しているもので、フォーム値ではありません。
+
+'post_key'は自動的にmixi側からランダムな文字列が返されます。
+メッセージを送信する(postまたはget_edit_diary_confirm)際にはプレビューで取得したこれらの値も必要です。
+
+なお、エラーがある場合、parse_send_message_previewはレスポンスコードを400、レスポンスメッセージを"Invalid Form Data"に変更します。
+返り値がなかった場合、再度レスポンスコードをチェックしてみてください。
+
+=head3 $item = $mixi->parse_send_message_confirm( [$response ]);
+
+メッセージ送信結果(send_message.plのメイン部)を解析します。
+返り値は、以下のようなハッシュリファレンスです。
+
+ {
+ 	'result' => 1,
+ 	'subject' => '送信完了しました。'
+ 	'banner' => {
+ 		'subject' => '',
+ 		'image' => 'http://img.mixi.jp/img/banner/yosoo03.gif',
+ 		'link' => 'http://mixi.jp/banner.pl?id=63'
+ 	},
+ }
+
+なお、コンテンツに「送信完了しました。」のメッセージが見つからない時は、返り値はありません。
+また、レスポンスが「データはありません。」だった時にも、返り値はありません。
+どちらの場合も、おそらくメッセージ送信は失敗しています。
+返り値がなかった場合、レスポンスコードが200であればレスポンスのコンテンツを、400であればレスポンスメッセージをチェックしてみてください。
+
+=head2 Fetch data
+
+直接データを取得するためのメソッドです。
+
+実際には、内部で自動的にページの取得と解析が行われます。
+返り値は、使用される解析メソッド(parse_~)に準じます。
+
+データ取得メソッドはコーディングを簡単にしますが、返り値がないときにはエラーが起きたのか、それとも本当に該当レコードがないのかの判断が難しいことに注意してください。
+こうした時には、logメソッドを上書きしておいてエラーメッセージ等を拾う、responseメソッドで直接HTTPレスポンスを取得して解析する、といった方法を考えてください(とは言え、そこまでしてしまうとgetメソッド+parse_~メソッドを使うより手間でしょう)。
+
+=head3 @items = $mixi->get_main_menu( [$url | $url => 'refresh'] )
+
+指定されたURLのメインメニューを取得します。
+返り値はparse_main_menuと同じです。
+
+指定されたURLが最後にgetまたはpostメソッドで取得したURLと同じとき、またはURLが指定されなかったときは、最後にgetまたはpostメソッドで取得したデータのメインメニューを返します。
+同一URLでも再取得したいときには、'refresh'を指定してください。
+
+=head3 @items = $mixi->get_banner( [$url | $url => 'refresh'] )
+
+指定されたURLのバナーを取得します。
+返り値はparse_bannerと同じです。
+
+指定されたURLが最後にgetまたはpostメソッドで取得したURLと同じとき、またはURLが指定されなかったときは、最後にgetまたはpostメソッドで取得したデータのメインメニューを返します。
+同一URLでも再取得したいときには、'refresh'を指定してください。
+
+=head3 @items = $mixi->get_tool_bar( [$url | $url => 'refresh'] )
+
+指定されたURLのツールバーを取得します。
+返り値はparse_tool_barと同じです。
+
+指定されたURLが最後にgetまたはpostメソッドで取得したURLと同じとき、またはURLが指定されなかったときは、最後にgetまたはpostメソッドで取得したデータのメインメニューを返します。
+同一URLでも再取得したいときには、'refresh'を指定してください。
+
+=head3 @items = $mixi->get_information( [$url | $url => 'refresh' | 'refresh'] );
+
+指定されたURLから、「管理者からのお知らせ」を取得します。
+URLを指定しなかった時は「ホーム」を対象にします。
+返り値はparse_informationと同じです。
+
+最後にgetまたはpostメソッドで取得したページが対象URLと同じ時は、その時のデータを返します。
+最新のデータを取得したい時は、'refresh'を指定してください。
+
+=head3 @items = $mixi->get_calendar( [$url | $url => 'refresh' | 'refresh'] );
+
+カレンダーを取得します。
+デフォルトでは今月のカレンダーを対象にしますが、URLを指定した時はそのページを対象にします。
+返り値はparse_calendarと同じです。
+
+最後にgetまたはpostメソッドで取得したページが対象URLと同じ時は、その時のデータを返します。
+最新のデータを取得したい時は、'refresh'を指定してください。
+
+=head3 $item = $mixi->get_calendar_term( [$url | $url => 'refresh' | 'refresh'] );
+
+カレンダーの期間(年月)を取得します。
+デフォルトでは今月のカレンダーを対象にしますが、URLを指定した時はそのページを対象にします。
+返り値はparse_calendar_termと同じです。
+
+最後にgetまたはpostメソッドで取得したページが対象URLと同じ時は、その時のデータを返します。
+最新のデータを取得したい時は、'refresh'を指定してください。
+
+=head3 $item = $mixi->get_calendar_next( [$url | $url => 'refresh' | 'refresh'] );
+
+カレンダーの「次の月」へのリンクを取得します。
+デフォルトでは「カレンダー」を対象にしますが、URLを指定した時はそのページを対象にします。
+返り値はparse_calendar_nextと同じです。
+
+最後にgetまたはpostメソッドで取得したページが対象URLと同じ時は、その時のデータを返します。
+最新のデータを取得したい時は、'refresh'を指定してください。
+
+=head3 $item = $mixi->get_calendar_previous( [$url | $url => 'refresh' | 'refresh'] );
+
+カレンダーの「前の月」へのリンクを取得します。
+デフォルトでは「カレンダー」を対象にしますが、URLを指定した時はそのページを対象にします。
+返り値はparse_calendar_previousと同じです。
+
+最後にgetまたはpostメソッドで取得したページが対象URLと同じ時は、その時のデータを返します。
+最新のデータを取得したい時は、'refresh'を指定してください。
+
+=head3 @items = $mixi->get_list_bookmark( [$url | $url => 'refresh' | 'refresh'] );
+
+お気に入りを取得します。
+デフォルトではホームの「お気に入り」を対象にしますが、URLを指定した時はそのページを対象にします。
+返り値はparse_list_bookmarkと同じです。
+
+最後にgetまたはpostメソッドで取得したページが対象URLと同じ時は、その時のデータを返します。
+最新のデータを取得したい時は、'refresh'を指定してください。
+
+=head3 @items = $mixi->get_list_comment( [$url | $url => 'refresh' | 'refresh'] );
+
+最新のコメントを取得します。
+デフォルトでは「最新のコメント」を対象にしますが、URLを指定した時はそのページを対象にします。
+返り値はparse_list_commentと同じです。
+
+最後にgetまたはpostメソッドで取得したページが対象URLと同じ時は、その時のデータを返します。
+最新のデータを取得したい時は、'refresh'を指定してください。
+
+=head3 @items = $mixi->get_list_community( [$url | $url => 'refresh' | 'refresh'] );
+
+コミュニティ一覧を取得します。
+デフォルトでは「コミュニティ一覧」を対象にしますが、URLを指定した時はそのページを対象にします。
+返り値はparse_list_communityと同じです。
+
+最後にgetまたはpostメソッドで取得したページが対象URLと同じ時は、その時のデータを返します。
+最新のデータを取得したい時は、'refresh'を指定してください。
+
+=head3 $item = $mixi->get_list_community_next( [$url | $url => 'refresh' | 'refresh'] );
+
+コミュニティ一覧の「次のページ」へのリンクを取得します。
+デフォルトでは「コミュニティ一覧」を対象にしますが、URLを指定した時はそのページを対象にします。
+返り値はparse_list_community_nextと同じです。
+
+最後にgetまたはpostメソッドで取得したページが対象URLと同じ時は、その時のデータを返します。
+最新のデータを取得したい時は、'refresh'を指定してください。
+
+=head3 $item = $mixi->get_list_community_previous( [$url | $url => 'refresh' | 'refresh'] );
+
+コミュニティ一覧の「前のページ」へのリンクを取得します。
+デフォルトでは「コミュニティ一覧」を対象にしますが、URLを指定した時はそのページを対象にします。
+返り値はparse_list_community_previousと同じです。
+
+最後にgetまたはpostメソッドで取得したページが対象URLと同じ時は、その時のデータを返します。
+最新のデータを取得したい時は、'refresh'を指定してください。
+
+=head3 @items = $mixi->get_list_diary( [$url | $url => 'refresh' | 'refresh'] );
+
+日記一覧を取得します。
+デフォルトでは「日記」を対象にしますが、URLを指定した時はそのページを対象にします。
+返り値はparse_list_diaryと同じです。
+
+最後にgetまたはpostメソッドで取得したページが対象URLと同じ時は、その時のデータを返します。
+最新のデータを取得したい時は、'refresh'を指定してください。
+
+=head3 $item = $mixi->get_list_diary_capacity( [$url | $url => 'refresh' | 'refresh'] );
+
+日記の「日記の使用状況」を取得します。
+デフォルトでは「日記」を対象にしますが、URLを指定した時はそのページを対象にします。
+返り値はparse_list_diary_capacityと同じです。
+
+最後にgetまたはpostメソッドで取得したページが対象URLと同じ時は、その時のデータを返します。
+最新のデータを取得したい時は、'refresh'を指定してください。
+
+=head3 $item = $mixi->get_list_diary_next( [$url | $url => 'refresh' | 'refresh'] );
+
+日記の「次のページ」へのリンクを取得します。
+デフォルトでは「日記」を対象にしますが、URLを指定した時はそのページを対象にします。
+返り値はparse_list_diary_nextと同じです。
+
+最後にgetまたはpostメソッドで取得したページが対象URLと同じ時は、その時のデータを返します。
+最新のデータを取得したい時は、'refresh'を指定してください。
+
+=head3 $item = $mixi->get_list_diary_previous( [$url | $url => 'refresh' | 'refresh'] );
+
+日記の「前のページ」へのリンクを取得します。
+デフォルトでは「日記」を対象にしますが、URLを指定した時はそのページを対象にします。
+返り値はparse_list_diary_previousと同じです。
+
+最後にgetまたはpostメソッドで取得したページが対象URLと同じ時は、その時のデータを返します。
+最新のデータを取得したい時は、'refresh'を指定してください。
+
+=head3 @items = $mixi->get_list_diary_monthy_menu( [$url | $url => 'refresh' | 'refresh'] );
+
+日記の各月のインデックスへのリンクを取得します。
+デフォルトでは「日記」を対象にしますが、URLを指定した時はそのページを対象にします。
+返り値はparse_list_diary_monthy_menuと同じです。
+
+最後にgetまたはpostメソッドで取得したページが対象URLと同じ時は、その時のデータを返します。
+最新のデータを取得したい時は、'refresh'を指定してください。
+
+=head3 @items = $mixi->get_list_friend( [$url | $url => 'refresh' | 'refresh'] );
+
+友人・知人一覧を取得します。
+デフォルトでは「友人・知人一覧」を対象にしますが、URLを指定した時はそのページを対象にします。
+返り値はparse_list_friendと同じです。
+
+最後にgetまたはpostメソッドで取得したページが対象URLと同じ時は、その時のデータを返します。
+最新のデータを取得したい時は、'refresh'を指定してください。
+
+=head3 $item = $mixi->get_list_friend_next( [$url | $url => 'refresh' | 'refresh'] );
+
+友人・知人一覧の「次のページ」へのリンクを取得します。
+デフォルトでは「友人・知人一覧」を対象にしますが、URLを指定した時はそのページを対象にします。
+返り値はparse_list_friend_nextと同じです。
+
+最後にgetまたはpostメソッドで取得したページが対象URLと同じ時は、その時のデータを返します。
+最新のデータを取得したい時は、'refresh'を指定してください。
+
+=head3 $item = $mixi->get_list_friend_previous( [$url | $url => 'refresh' | 'refresh'] );
+
+友人・知人一覧の「前のページ」へのリンクを取得します。
+デフォルトでは「友人・知人一覧」を対象にしますが、URLを指定した時はそのページを対象にします。
+返り値はparse_list_friend_previousと同じです。
+
+最後にgetまたはpostメソッドで取得したページが対象URLと同じ時は、その時のデータを返します。
+最新のデータを取得したい時は、'refresh'を指定してください。
+
+=head3 @items = $mixi->get_list_message( [$url | $url => 'refresh' | 'refresh'] );
+
+「最近の受信メッセージ」を取得します。
+デフォルトでは「最近の受信メッセージ」を対象にしますが、URLを指定した時はそのページを対象にします。
+返り値はparse_list_messageと同じです。
+
+最後にgetまたはpostメソッドで取得したページが対象URLと同じ時は、その時のデータを返します。
+最新のデータを取得したい時は、'refresh'を指定してください。
+
+=head3 @items = $mixi->get_list_outbox( [$url | $url => 'refresh' | 'refresh'] );
+
+「最近の送信メッセージ」を取得します。
+デフォルトでは「送信メッセージ」の最初のページを対象にしますが、URLを指定した時はそのページを対象にします。
+返り値はparse_list_messageと同じです。
+
+=head3 @items = $mixi->get_new_album( [$url | $url => 'refresh' | 'refresh'] );
+
+マイミクシィ最新アルバムを取得します。
+デフォルトでは「マイミクシィ最新アルバム」を対象にしますが、URLを指定した時はそのページを対象にします。
+返り値はparse_new_albumと同じです。
+
+最後にgetまたはpostメソッドで取得したページが対象URLと同じ時は、その時のデータを返します。
+最新のデータを取得したい時は、'refresh'を指定してください。
+
+=head3 @items = $mixi->get_new_bbs( [$url | $url => 'refresh' | 'refresh'] );
+
+コミュニティ最新書き込みを取得します。
+デフォルトでは「コミュニティ最新書込み」を対象にしますが、URLを指定した時はそのページを対象にします。
+返り値はparse_new_bbsと同じです。
+
+最後にgetまたはpostメソッドで取得したページが対象URLと同じ時は、その時のデータを返します。
+最新のデータを取得したい時は、'refresh'を指定してください。
+
+=head3 $item = $mixi->get_new_bbs_next( [$url | $url => 'refresh' | 'refresh'] );
+
+コミュニティ最新書き込みの「次のページ」へのリンクを取得します。
+デフォルトでは「コミュニティ最新書き込み」を対象にしますが、URLを指定した時はそのページを対象にします。
+返り値はparse_new_bbs_nextと同じです。
+
+最後にgetまたはpostメソッドで取得したページが対象URLと同じ時は、その時のデータを返します。
+最新のデータを取得したい時は、'refresh'を指定してください。
+
+=head3 $item = $mixi->get_new_bbs_previous( [$url | $url => 'refresh' | 'refresh'] );
+
+コミュニティ最新書き込みの「前のページ」へのリンクを取得します。
+デフォルトでは「コミュニティ最新書き込み」を対象にしますが、URLを指定した時はそのページを対象にします。
+返り値はparse_new_bbs_previousと同じです。
+
+最後にgetまたはpostメソッドで取得したページが対象URLと同じ時は、その時のデータを返します。
+最新のデータを取得したい時は、'refresh'を指定してください。
+
+=head3 @items = $mixi->get_new_comment( [$url | $url => 'refresh' | 'refresh'] );
+
+日記コメント記入履歴を取得します。
+デフォルトでは「日記コメント記入履歴」を対象にしますが、URLを指定した時はそのページを対象にします。
+返り値はparse_new_commentと同じです。
+
+最後にgetまたはpostメソッドで取得したページが対象URLと同じ時は、その時のデータを返します。
+最新のデータを取得したい時は、'refresh'を指定してください。
+
+=head3 @items = $mixi->get_new_diary( [$url | $url => 'refresh' | 'refresh']  [,'keyword' => $keyword]);
+
+新着日記検索を取得します。
+デフォルトでは「新着日記検索」を対象にしますが、URLを指定した時はそのページを対象にします。
+返り値はparse_new_diaryと同じです。
+
+検索キーワードを指定する時は、URLに埋め込むか、引数で与えてください。
+どちらもなければ検索キーワード無しでの検索結果が返されます。
+両方指定された場合は、URL中のキーワードが優先されます。
+
+最後にgetまたはpostメソッドで取得したページが対象URLと同じ時は、その時のデータを返します。
+最新のデータを取得したい時は、'refresh'を指定してください。
+
+=head3 $item = $mixi->get_new_diary_next( [$url | $url => 'refresh' | 'refresh'] [,'keyword' => $keyword]);
+
+新着日記検索の「次のページ」へのリンクを取得します。
+デフォルトでは「新着日記検索」を対象にしますが、URLを指定した時はそのページを対象にします。
+返り値はparse_new_diary_nextと同じです。
+
+検索キーワードは、URLに埋め込むか、引数で与えてください。
+新着日記検索ではキーワードを指定しないと「次のページ」「前のページ」が見れないので、URL中にも引数にもキーワードがない時は、確実に失敗することに注意してください。
+
+最後にgetまたはpostメソッドで取得したページが対象URLと同じ時は、その時のデータを返します。
+最新のデータを取得したい時は、'refresh'を指定してください。
+
+=head3 $item = $mixi->get_new_diary_previous( [$url | $url => 'refresh' | 'refresh']  [,'keyword' => $keyword]);
+
+新着日記検索の「前のページ」へのリンクを取得します。
+デフォルトでは「新着日記検索」を対象にしますが、URLを指定した時はそのページを対象にします。
+返り値はparse_new_diary_previousと同じです。
+
+検索キーワードは、URLに埋め込むか、引数で与えてください。
+新着日記検索ではキーワードを指定しないと「次のページ」「前のページ」が見れないので、URL中にも引数にもキーワードがない時は、確実に失敗することに注意してください。
+
+最後にgetまたはpostメソッドで取得したページが対象URLと同じ時は、その時のデータを返します。
+最新のデータを取得したい時は、'refresh'を指定してください。
+
+=head3 @items = $mixi->get_new_friend_diary( [$url | $url => 'refresh' | 'refresh'] );
+
+マイミクシィ最新日記を取得します。
+デフォルトでは「マイミクシィ最新日記」を対象にしますが、URLを指定した時はそのページを対象にします。
+返り値はparse_new_friend_diaryと同じです。
+
+最後にgetまたはpostメソッドで取得したページが対象URLと同じ時は、その時のデータを返します。
+最新のデータを取得したい時は、'refresh'を指定してください。
+
+=head3 $item = $mixi->get_new_friend_diary_next( [$url | $url => 'refresh' | 'refresh'] );
+
+マイミクシィ最新日記の「次のページ」へのリンクを取得します。
+デフォルトでは「マイミクシィ最新日記」を対象にしますが、URLを指定した時はそのページを対象にします。
+返り値はparse_new_friend_diary_nextと同じです。
+
+最後にgetまたはpostメソッドで取得したページが対象URLと同じ時は、その時のデータを返します。
+最新のデータを取得したい時は、'refresh'を指定してください。
+
+=head3 $item = $mixi->get_new_friend_diary_previous( [$url | $url => 'refresh' | 'refresh'] );
+
+マイミクシィ最新日記の「前のページ」へのリンクを取得します。
+デフォルトでは「マイミクシィ最新日記」を対象にしますが、URLを指定した時はそのページを対象にします。
+返り値はparse_new_friend_diary_previousと同じです。
+
+最後にgetまたはpostメソッドで取得したページが対象URLと同じ時は、その時のデータを返します。
+最新のデータを取得したい時は、'refresh'を指定してください。
+
+=head3 @items = $mixi->get_new_review( [$url | $url => 'refresh' | 'refresh'] );
+
+マイミクシィ最新レビューを取得します。
+デフォルトでは「マイミクシィ最新レビュー」を対象にしますが、URLを指定した時はそのページを対象にします。
+返り値はparse_new_reviewと同じです。
+
+最後にgetまたはpostメソッドで取得したページが対象URLと同じ時は、その時のデータを返します。
+最新のデータを取得したい時は、'refresh'を指定してください。
+
+=head3 $id = $mixi->get_self_id( ['refresh'] );
+
+おすすめレビュー(list_review.pl)の「レビューを書く」ボックスを解析し、
+自分のIDを返します。
+IDを取得できなかった時の返り値は0です。
+あしあと数を取得します。
+返り値はparse_self_idと同じです。
+
+最後にgetまたはpostメソッドで取得したページが「おすすめレビュー」の時は、その時のデータを返します。
+最新のデータを取得したい時は、'refresh'を指定してください。
+
+=head3 @items = $mixi->get_show_log( [$url | $url => 'refresh' | 'refresh'] );
+
+あしあとを取得します。
+デフォルトでは「あしあと」を対象にしますが、URLを指定した時はそのページを対象にします。
+返り値はparse_show_logと同じです。
+
+最後にgetまたはpostメソッドで取得したページが対象URLと同じ時は、その時のデータを返します。
+最新のデータを取得したい時は、'refresh'を指定してください。
+
+=head3 $count = $mixi->get_show_log_count( [$url | $url => 'refresh' | 'refresh'] );
+
+あしあと数を取得します。
+デフォルトでは「あしあと」を対象にしますが、URLを指定した時はそのページを対象にします。
+返り値はparse_show_log_countと同じです。
+
+最後にgetまたはpostメソッドで取得したページが対象URLと同じ時は、その時のデータを返します。
+最新のデータを取得したい時は、'refresh'を指定してください。
+
+=head3 $item = $mixi->get_show_friend_outline( $url [ => 'refresh'] );
+
+ニックネームや写真などの情報を取得します。
+このメソッドでは、URLの指定が必須です。
+返り値はparse_show_friend_outlineと同じです。
+
+最後にgetまたはpostメソッドで取得したページが対象URLと同じ時は、その時のデータを返します。
+最新のデータを取得したい時は、'refresh'を指定してください。
+
+=head3 $item = $mixi->get_show_friend_profile( $url [ => 'refresh'] );
+
+プロフィールを取得します。
+このメソッドでは、URLの指定が必須です。
+返り値はparse_show_friend_profileと同じです。
+
+最後にgetまたはpostメソッドで取得したページが対象URLと同じ時は、その時のデータを返します。
+最新のデータを取得したい時は、'refresh'を指定してください。
+
+=head3 $item = $mixi->get_view_diary( $url [ => 'refresh'] );
+
+日記を取得します。
+このメソッドでは、URLの指定が必須です。
+返り値はparse_view_diaryと同じです。
+
+最後にgetまたはpostメソッドで取得したページが対象URLと同じ時は、その時のデータを返します。
+最新のデータを取得したい時は、'refresh'を指定してください。
+
+=head3 $item = $mixi->get_view_message( $url [ => 'refresh'] );
+
+メッセージを取得します。
+このメソッドでは、URLの指定が必須です。
+返り値はparse_view_messageと同じです。
+
+最後にgetまたはpostメソッドで取得したページが対象URLと同じ時は、その時のデータを返します。
+最新のデータを取得したい時は、'refresh'を指定してください。
+
+=head3 @items = $mixi->get_view_message_form( $url [ => 'refresh'] );
+
+メッセージを取得します。
+このメソッドでは、URLの指定が必須です。
+返り値はparse_view_messageと同じです。
+
+最後にgetまたはpostメソッドで取得したページが対象URLと同じ時は、その時のデータを返します。
+最新のデータを取得したい時は、'refresh'を指定してください。
+
+=head2 Post data
+
+直接データを投稿するためのメソッドです。
+
+実際には、内部で自動的に適切なページへのpostが行われます。
+
+=head3 @items = $mixi->get_add_diary_preview('diary_title' => $title, 'diary_body' => $body [, 'photo1' => $path_to_photo1] [, 'photo2' => $path_to_photo2] [, 'photo3' => $path_to_photo3]);
+
+日記作成ページに引数のデータを送信し、プレビューページを取得して解析します。
+返り値はparse_add_diary_previewと同じです。
+
+=head3 @items = $mixi->get_add_diary_confirm('diary_title' => $title, 'diary_body' => $body, 'post_key' => $key [, 'photo1' => $path_to_photo1] [, 'photo2' => $path_to_photo2] [, 'photo3' => $path_to_photo3]);
+
+日記を投稿します。
+返り値はparse_add_diary_confirmと同じです。
+
+=head3 @items = $mixi->get_delete_diary_preview('id' => $id);
+
+日記削除の確認画面を取得し、解析します。
+返り値はparse_delete_diary_previewと同じです。
+
+=head3 @items = $mixi->get_delete_diary_confirm('id' => $id, 'post_key' => $key);
+
+日記を削除します。
+返り値はparse_delete_diary_confirmと同じです。
+
+=head3 @items = $mixi->get_edit_diary_preview($url|'id' => $id);
+
+日記を編集(再投稿)ページを取得し、解析します。
+返り値はparse_edit_diary_previewと同じです。
+
+=head3 @items = $mixi->get_edit_diary_image($url|'id' => $id);
+
+日記を編集(再投稿)ページを取得し、解析します。
+返り値はparse_edit_diary_imageと同じです。
+
+=head3 @items = $mixi->get_edit_diary_confirm('id' => $id, 'diary_title' => $title, 'diary_body' => $body [, 'photo1' => $path_to_photo1] [, 'photo2' => $path_to_photo2] [, 'photo3' => $path_to_photo3]);
+
+日記を編集(再投稿)します。
+返り値はparse_edit_diary_confirmと同じです。
+
+=head3 @items = $mixi->get_send_message_preview('id' => $id, 'subject' => $subject, 'body' => $body);
+
+$idのユーザー宛のメッセージ送信ページに引数のデータを送信し、プレビューページを取得して解析します。
+返り値はparse_send_message_previewと同じです。
+
+=head3 @items = $mixi->get_send_message_confirm('id' => $id, 'subject' => $subject, 'body' => $body [, 'post_key' => $key]);
+
+$idのユーザー宛のメッセージを送信します。
+返り値はparse_send_message_confirmと同じです。
+
+=head2 Convert URL
+
+URLを絶対URLに変換するメソッドです。
+
+=head3 $url = $mixi->absolute_url($url [, $base])
+
+$baseをベースURLとして、絶対URLを返します。
+$baseが指定されなかった時は、mixiのトップページ(0.13版では"http://mixi.jp/")をベースにします。
+URLの代わりに'login'、'show_logs'などの'.pl'を省いたファイル名を指定しても構いません。
+
+=head3 $url = $mixi->absolute_linked_url($url)
+
+最後にgetまたはpostメソッドで取得したページのURLをベースURLとして、絶対URLを返します。
+URLの代わりに'login'、'show_logs'などの'.pl'を省いたファイル名を指定しても構いません。
+
+=head3 $url = $mixi->query_sorted_url($url)
+
+URLのクエリ部分("?"から後ろ)をキーの昇順で並べ替えます。
+また、値の空白が"%20"に変換されているところがあれば+に置換します。
+結果として、同じクエリ内容であれば同じURLに書き直されます。
+
+このメソッドは試験用の内部メソッドで使用するために設けられましたが、URLをキーとしたキャッシュなどをする際には有用でしょう。
+
+=head2 Cookies
+
+Cookieの保存や読込を行うためのメソッドです。
+
+=head3 $mixi->enable_cookies($cookie_file)
+
+cookieを有効にします。
+これはログイン(login)、Cookieの読み込み(load_cookies)などの際に自動的に行われるので、通常は明示的に行う必要はありません。
+ログインなどに先立って、Cookieを操作したい時などのために用意されています。
+
+返り値はオブジェクト自身です。
+
+=head3 $mixi->save_cookies($cookie_file)
+
+cookieの内容を指定されたファイルに保存します。
+成功時には1、失敗時には0を返します。
+
+=head3 $mixi->load_cookies($cookie_file)
+
+指定されたファイルからCookieデータを読み込みます。
+成功時には1、失敗時には0を返します。
+
+=head2 Internal methods
+
+以下はWWW::Mixiの内部メソッドです。
+
+基本的にはWWW::Mixiの各メソッドからのみ使用されることを前提としており、後のバージョンでは仕様が変更されたりメソッドが廃止されるかもしれません。
+できるだけ利用しない方が良いと思います。
+
+=head3 $mixi->log
+
+ログの出力などを行うメソッドで、内部で利用されます。
+デフォルトでは、callback_logメソッドを呼び出します。
+
+=head3 $mixi->dumper_log
+
+引数のダンプをログとして出力または保持するメソッドで、内部で利用されます。
+実際の出力には、logメソッドを使用します。
+
+=head3 $mixi->abort
+
+エラー時のabort処理を行うメソッドで、内部で利用されます。
+デフォルトでは、callback_abortメソッドを呼び出します。
+
+=head3 $mixi->callback_log
+
+引数をログとしてシフトJISに変換し、標準出力に出力します。
+また、ログにエラーメッセージが含まれていれば、abortメソッドを呼び出します。
+これはlogメソッドのデフォルトの実装で、内部で利用されます。
+
+これ以外のログ処理をしたいときには、コンストラクト時に
+
+ $mixi = WWW::Mixi->new($mail, $pass, -log => \&my_callback_log);
+
+のようにして、代わりのログ出力メソッドを定義してやってください。
+
+=head3 $mixi->callback_abort
+
+dieを実行します。
+これはabortメソッドのデフォルトの実装で、内部で利用されます。
+
+=head3 $str = $mixi->rewrite
+
+データ解析時のテキスト値の処理を行うメソッドです。
+デフォルトでは、callback_rewriteメソッドを呼び出します。
+
+=head3 $str = $mixi->callback_rewrite($str);
+
+HTMLタグの削除とHTMLエスケープの解除(アンエスケープ)を行います。
+これはrewriteメソッドのデフォルトの実装で、内部で利用されます。
+
+=head3 $str = $mixi->escape($str);
+
+HTMLエスケープした文字列を返します。
+
+=head3 $str = $mixi->unescape($str);
+
+HTMLアンエスケープした文字列を返します。
+
+=head3 $str = $mixi->remove_tag($str);
+
+タグを削除した文字列を返します。
+HTMLに限らず、<~>のほとんどを削除する事に注意してください。
+通常は、unescapeの前に実行されるものです。
+
+=head3 $str = $mixi->remove_diary_tag($str);
+
+日記に使われているものと思われるタグを削除します。
+新着日記中に混入する、エスケープされた日記用のタグなどを取り除くのに使用することができます。
+
+タグが途中で切れている場合には、削除されません。
+
+=head3 $mixi->redirect_ok
+
+リダイレクトの可否を決めるメソッドで、WWW::Mixiの場合は常に1を返します。
+つまり、リダイレクトは常に自動的に実行されます。
+
+このメソッドはLWP::RobotUA(を介してLWP::UserAgent)から継承したredirect_okメソッドを上書きしています。
+
+=head3 @items = $mixi->parse_standard_history( [$response] );
+
+標準的な履歴ページのメイン部分用の解析メソッドです。
+最近のコメント(list_comment.plのメイン部)、コミュニティ最新書き込み(new_bbs.plのメイン部)、マイミクシィ最新日記(new_friend_diary.plのメイン部)、マイミクシィ最新アルバム(new_albumのメイン部)、マイミクシィ最新レビュー(new_review.plのメイン部)、日記コメント記入履歴(new_comment)を解析できます。
+
+返り値は、項目ごとに以下のようなハッシュリファレンスにしたものの配列です。
+
+ {
+ 	'subject' => 'こんにちわ。',
+ 	'link' => 'http://mixi.jp/view_diary.pl?id=xxxxxx',
+ 	'name' => '塚本牧生',
+ 	'time' => '2004/08/18 13:18'
+ }
+
+なお、それぞれ専用のメソッドを用意してありますので、そちらを使う方が無難です。
+現在はこれらのページをparse_standard_historyで解析できるため、内部ではparse_standard_historyを呼び出しているだけですが、将来についてはmixi側の変更があるかも知れません。
+その時には専用メソッドでしか解析できなくなり、parse_standard_historyを使っていると手直しが必要になるでしょう。
+
+=head3 @items = $mixi->parse_standard_form( [$response] );
+
+標準的なプレビューページ用のフォーム解析メソッドです。
+ページ内のフォームを抽出し、formタグのactionアトリビュートで指定されているURL、inputタグのアトリビュートで指定されているnameとvalueのペア、textareタグのnameと内容のペアを解析できます。
+返り値は、フォームごとに以下のようなハッシュリファレンスにしたものの配列です。
+__action__以外のキーは解析するフォームごとに異なることに注意してください。
+
+ {
+ 	'__action__' => 'http://mixi.jp/add_diary.pl',
+ 	'submit' => 'confirm',
+ 	'diary_title' => '今日の日記',
+ 	'diary_body' => '今日は朝から晩だった。生まれたばかりの...',
+ 	'orig_size' => 1,
+ 	'packed' => 'xxxxxxx_xxx_xxxx',
+ 	'post_key' => 'xxxxxxx_xxx',
+ 	'link' => 'http://mixi.jp/view_diary.pl?id=xxxxxx',
+ 	'name' => '塚本牧生',
+ 	'time' => '2004/08/18 13:18'
+ }
+
+=head3 $url = $mixi->set_response( $url [ => 'refresh'] )
+
+responseメソッドの返り値を、$url取得時のデータになるようにセットします。
+これにあわせて、各解析メソッドのデフォルトの解析対象データも$urlのものになります。
+
+デフォルトでは、$urlが最後にgetまたはpostで取得したURLと異なる時だけ、$urlをgetで取得します。
+これにより、不要な再取得の負荷と時間をかけないようにしています。
+この場合でもデータを再取得し、最新のデータにしたい時には'refresh'を指定してください。
+
+=head3 @items = $mixi->post_add_diary('submit' => $action, 'diary_title' => $title, 'diary_body' => $body, [, 'photo1' => $path_to_photo1, 'photo2' => $path_to_photo2, 'photo3' => $path_to_photo3] [, 'orig_size' => 1]] [, 'packed' => $hash_value]);
+
+日記作成ページに引数のデータを送信します。
+返り値は送信時のHTTP::Responseオブジェクトです。
+
+アクションには、確認画面を取得する時は"main"、実際に投稿する時には"confirm"を指定します。
+写真1~3には、確認画面を取得する時はファイルパスを指定し、「そのままのサイズで送信」する時には、orig_size => 1も指定します。
+
+実際に投稿する時には、写真1~3などの代わりに、確認画面に表示されたハッシュ値(packedフィールドの値)を指定します。
+
+=head3 @items = $mixi->post_edit_diary('submit' => $action, 'diary_id' => $id, 'diary_title' => $title, 'diary_body' => $body, 'photo1' => $path_to_photo1, 'photo2' => $path_to_photo2, 'photo3' => $path_to_photo3);
+
+日記編集ページに引数のデータを送信します。
+返り値は送信時のHTTP::Responseオブジェクトです。
+
+アクションには、編集する時には"main"を指定します。
+写真1~3には、ファイルパスを指定します。
+
+=head3 @items = $mixi->post_delete_diary('submit' => $action, 'diary_id' => $id);
+
+日記削除ページに引数のデータを送信します。
+返り値は送信時のHTTP::Responseオブジェクトです。
+
+アクションには、確認画面を取得する時は"main"、実際に投稿する時には"confirm"を指定します。
+
+=head3 $time = $mixi->convert_login_time($time);
+
+「お気に入り」に表示される「45分以内」などの記述を時刻に直します。
+
+=head2 Testing method
+
+以下はWWW::Mixiの試験用のメソッドです。
+
+=head3 perl -MWWW::Mixi -e "WWW::Mixi::test('email', 'password' [, 'logfile'])"
+
+WWW::Mixiの各機能を試験するためのメソッドです。
+
+0.13版ではコンストラクタ、ログイン、データの取得、Cookieの保存が試験されます。
+これらは内部でURLの変換、ログイン状況の取得、ページ取得(getとpost)、解析などのメソッドを使用しています。
+
+email、passwordはmixiにログインできるものを指定してください。
+ログファイルは解析結果を出力するためのものです。
+未指定時は'LWP-Mixi-x.xx-test.log'が使用されます。
+
+=head1 RESPONSE CODE
+
+いくつかのケースでは、mixiがレスポンスコード"200"などを返す場合でも、実際のコンテンツの内容からWWW::Mixiがレスポンスコードとレスポンスメッセージを置き換えます。
+これにより、WWW::Mixiはユーザーのリクエストが"実質的に"成功した場合にのみis_successが真になり、"実質的に"失敗した場合には偽になる(is_errorが真になる)ように振舞います。
+
+ここで使用されるレスポンスコードは一般的なものなので、例えばレスポンスコード"400"は本当にmixiからBad Requestが返された場合もありますし、コンテンツが「データがありません」というものである場合もあります。
+レスポンスメッセージはWWW::Mixiが独自のものをセットしますので、こちらで区別してください。
+
+=over 4
+
+=item "400"
+
+以下のケースで、レスポンスコードは400に置き換えられます。
+
+=over 8
+
+=item No Data
+
+例えばidを指定せずにview_diary.plにアクセスした時などに、「データはありません。」という一言だけのページが返ってきます。
+ほとんどのケースでは、原因は指定すべきクエリ項目が指定されていないケースなので、WWW::Mixiはこのレスポンスを「400 Bad Request」の一種とみなします。
+
+=item Invalid Form Data (エラーメッセージ)
+
+日記投稿で表題が指定されていない時などに、プレビュー画面にエラーメッセージが表示されます。
+parse_~_previewメソッドで投稿プレビューを解析時、WWW::Mixiはこのレスポンスを「400 Bad Request」の一種とみなします。
+
+他のケースと違い、parse_~_previewメソッドで解析を行うまではレスポンスコードとレスポンスメッセージの置き換えが行われない点に注意してください。
+request実施直後は、通常はレスポンスコードは200などでしょう。
+
+=back
+
+Invalid Form Dataに続くエラーメッセージはmixiが返したもので、通常は日本語(文字コードはEUC)であることに注意してください。
+このメッセージをそのまま出力する際には、例えば以下のようにして文字コードを適切に変換してやるべきです。
+
+ use Jcode;
+ use WWW::Mixi
+ my $mixi = WWW::Mixi->new('your @ email', 'yourpassword');
+ my $res = $mixi->login;
+ if ($res->code == 401) {
+   print jcode($res->message)->sjis, "\n";
+   ...
+ }
+
+=item "401"
+
+以下のケースで、レスポンスコードは401に置き換えられます。
+現在のところ、mixiはベーシック認証などを求めないため、エラーコード401はすべてこのケースとみなして問題ないでしょう。
+
+=over 8
+
+=item Login Required
+
+ログインフォームが表示されています。
+おそらく未ログインか、別のブラウザなどでログアウトしたため、再ログインが必要な状態です。
+
+=item Login Failed (エラーメッセージ)
+
+ログインフォームとともに、エラーメッセージが表示されています。
+おそらくログインに失敗した状態で、エラーメッセージからより正確な状況を判断してください。
+
+=back
+
+ログイン失敗時のエラーメッセージはmixiが返したもので、通常は日本語(文字コードはEUC)であることに注意してください。
+このメッセージをそのまま出力する際には、文字コードを適切に変換してやるべきです。
+
+=item "403"
+
+以下のケースで、レスポンスコードは403に置き換えられます。
+
+=over 8
+
+=item Closed content
+
+「アクセスできません。」という一言だけのページが返ってきます。
+おそらく、公開範囲が「友人まで」など、アクセス者が閲覧できないコンテンツ(日記など)にアクセスした場合です。
+
+=back
+
+=item "503"
+
+以下のケースで、レスポンスコードは503に置き換えられます。
+
+=over 8
+
+=item Too frequently requests
+
+「間隔を空けない連続的なページの遷移・更新を頻繁におこなわれているため...」という一文だけのページが返ってきます。
+おそらく、Mixi側で設定されているアクセス制限間隔より短い間隔でアクセスしたことにより、アクセスが拒否されています。
+この状況は、数分から数十分後に解除されるようです。
+
+通常、WWW::Mixiは十分に長いインターバルを置いてアクセスするため、この問題は起こらないはずです。
+明示的にアクセス間隔を短くしたか、多重に動かしているなどによることが考えられます。
+WWW::Mixiはmixiに多大な負荷をかけないなどの考慮を前提に配布・公開を黙認されていますので、このエラーが出るようであればツールの設計を見直すことを強く推奨します。
+
+=back
+
+=back
+
+=head1 SEE ALSO
+
+L<LWP::UserAgent>, L<WWW::RobotUA>, L<HTTP::Request::Common>
+
+=head1 AUTHORS
+
+WWW::Mixi is written by TSUKAMOTO Makio <tsuka****@gmail*****>
+
+Some bug fixes submitted by Topia (http://clovery.jp/), shino (http://www.freedomcat.com/), makamaka (http://www.donzoko.net/), あっしゅ, slash/onigawara (http://www.okoshi.org/), Mami Komura (http://www.warehouse56.com/).
+get_ and post_add_diary, get_ and post_delete_diary, parse_list_diary, parse_list_diary_monthly_menu and parse_new_diary contributed by DonaDona (http://hsj.jp/).
+get_ and parse_view_diary contributed by shino (http://www.freedomcat.com/).
+get_ and parse_list_outbox contributed by AsO (http://www.bx.sakura.ne.jp/~clan/rn/cgi-bin/index.cgi).
+get_ and post_send_message contributed by noname (http://untitled.rootkit.jp/diary/).
+
+=head1 COPYRIGHT
+
+Copyright 2004-2005 TSUKAMOTO Makio.
+
+This library is free software; you can redistribute it and/or
+modify it under the same terms as Perl itself.


Affelio-cvs メーリングリストの案内
Back to archive index