iPhone/iPadのホーム画面コンテスト開催中!賞品は iTunes カード!

Monthly Archive2007/05



PHP 2007/05/31 14:39

引数を名前で渡す

引数が多い時に困るのはみんな一緒ですね。

C++とかJavaで良く見るプログラミングスタイルだが、こうやってひたすら数字だけが並んでいるとやたらと読みにくい。三日後に見たらどのパラメーターが何なのかが思い出せなくて、コンストラクターのソースコードを参照せねばならない。

Life is beautiful: 「パラメーターのプロパティ渡し」でプログラムを読みやすくする、というアイデアはどうだろう

PHPのコンストラクタを名前付き引数で呼ぶアイデアはid:shimookaさんが書かれているので、ここでは通常のメソッドについて考えてみました。

いまいちなコードですが、引数省略時のデフォルト値、存在しない引数名が来た時・必須引数が無い場合に例外を投げるようにしてます。

PHP:
  1. <?php
  2. class IllegalArgumentException extends Exception {}
  3.  
  4. class Hoge {
  5.   protected function getParam(array &$params, $key, $isMust = false, $default = null) {
  6.     if (array_key_exists($key, $params)) {
  7.       $v = $params[$key];
  8.       unset($params[$key]);
  9.       return $v;
  10.     } else {
  11.       if ($isMust) {
  12.         throw new IllegalArgumentException();
  13.       } else {
  14.         return $default;
  15.       }
  16.     }
  17.   }
  18. }
  19.  
  20. class Foo extends Hoge {
  21.   public function func1(array $params = array()) {
  22.     $id = $this->getParam($params, 'id', true);
  23.     $name = $this->getParam($params, 'name', false, 'NO NAME');
  24.     if (count($params)> 0) {
  25.       throw new IllegalArgumentException();
  26.     }
  27.                      
  28.     printf("id=%s name=%s\n", $id, $name);
  29.   }
  30. }
  31.                
  32. $obj = new Foo();
  33. // id=1 name=hoge     
  34. $obj->func1(array('name' => 'hoge', 'id' => 1));
  35. // id=1 name=NO NAME
  36. $obj->func1(array('id' => 1));
  37. //  Uncaught exception 'IllegalArgumentException'
  38. $obj->func1();
  39. //  Uncaught exception 'IllegalArgumentException'
  40. $obj->func1(array('name' => 'hoge', 'id' => 1, 'email' => 'hoge@example.com'));

引数定義をメソッド宣言とは別に持つのはいまいちですね、はい。

ちなみにPythonは言語としてこの機能をサポートしているようです(via: odz buffer)。あとVBも同じような機能があります(via: 位置と名前による引数渡し)。

PHP & 雑記 2007/05/30 03:33

PHPを今まさに使っている(学んでいる)人へ

PHPはとかく非難されやすい言語です。「WebのVB」と揶揄されるように他言語の利用者(特にLL系)からはあまり良い評判を見ません。

PHPを仕事で使ってる人やこれから学ぼうとしている人の中には

「ああ~PHPっていけてないんだ。」

と感じている人もいるでしょう。

「このままPHPを使っていて良いんだろうか。」

と不安に駆られる人もいるでしょう。

開発経験がある程度あって複数の言語が扱える方ならこのような批判を見ても、ご自身で判断が下せるかと思います。(なのでそのような方達はこのエントリの対象ではありません。)

しかしそうでない方、特に今まさにPHPを学んでいる方はWeb上で繰り広げられるPHP批判に不安になったのではないでしょうか。

趣味でやっている方なら「じゃあRubyにするか」と言語を変えることできますが、仕事や学校でPHPをやっているとそう簡単に言語を変えることはできません。このままじゃ「いけてないプログラマーになるんじゃないか・・・」と不安になったり。。。

ここで一言

PHPを使っても大丈夫なんです!!

理由を4つばかり。

PHPについて

まずPHP自身について。

PHPには豊富な関数があり様々な機能を利用することができます。またextensionによってC/C++で書かれたライブラリをPHP自体に組み込む事ができます。(ミサイルを飛ばしたりw)

また色々と批判の多いPHP言語仕様ですが、C/Javaに似た文法ですし、オブジェクト指向もいちおうサポートしています。ですのでPHPの後にJavaをやるという際にもわりとスムーズに移行することができます。

私自身VBAでオブジェクト指向の雰囲気を見て、PHP3で何となくオブジェクト指向っぽい事をやって、Javaで開発したという経験があります。特にPHPとJavaはextendsやthis、try/catchなど似た構文が使われており理解が早いと思います。

動作環境の安定性、豊富な実績

次に動作環境の安定性、豊富な実績です。

プログラミング言語は言語だけで成立するものではなく何らかの形で動作する環境が必要です。特にWebシステムの場合はApacheなどWebサーバとの連携が必須となります。Apache+PHP(mod_php)の組み合わせは様々なサーバで動作しており、多くのレンタルサーバではPHPが動作するようになっています。

さらにYahoo!やGREEなど数多くのサイトがPHPでWebシステムを稼働させています。

またLLではネックになりがちな実行速度についてもAPC/eAcceleratorといったコードキャッシュ・アクセラレータが存在します。これにより実行速度を向上させることができます。これらのツールは実験的なものではなく、実際に数万~数十万人のユーザをさばくような有名サイトで稼働しています。(PHP6ではAPCが正式に採用されるという話しもあります)

豊富なフレームワークやライブラリ

次は豊富なフレームワークやライブラリです。

PEARをはじめとした有用なライブラリ群が数多く公開されています。さらに昨今ではCakePHPやSymfony、Ethnaといったフレームワークもあります。これらを使うことにより効率的な開発を行うことができます。

どうせ使う言語は変わる

最後は使う言語はPHPだけではないという事です。

今はPHPをやらざるを得ない状況でも、開発を続けている限りそれが一生涯続くという事はまず無いと思います。いずれは他の言語も学ぶようになるので、それまではしっかりとPHPを習得しておいた方が良いです。PHPは良くも悪くもWebシステム開発では今や主流とも言える言語なので習得しておけば他言語を学ぶ際に基準となります。

PHPでWebシステムを開発していけばWebシステムを作る上で必要となるスキルは身に付きます。このスキルはPHP以外の言語に移行したところで無駄になるわけではありません。Webシステムを開発する上で必要な概念はどの言語を使っても同じです。(ここではWebシステムとしていますが、PHPではバッチ処理などWeb以外の箇所を開発することもできます。なので当然ながらそのスキルも生きてきます。)

もちろん私自身PHPに不満点はありますし、PHP以外に素晴らしい言語もあります。しかし一つでも自分が自由自在に書ける言語があるという事はシステム開発を行う上で大きな礎となります。

PHPを今まさに使っている方、学んでいる方、自信を持って頑張っていきましょう。

[2007/06/02:追記]
はてぶでid:shomaさんがPHPを使ってるサイトを紹介して頂けたので追記しておきます。(ありがとうございます。)

PHPを使ってる有名サイト:Yahoo!, GREE, digg, facebook, CNET, Wikipedia, goo, wordpress, 楽天

Webサービス & twitter 2007/05/25 18:39

Twitter検索に「本文のみ」検索を追加しました

Twitter検索に「本文のみ」を検索する機能を追加しました。

当初はFriends探しに使おうと思い、できるだけ多くの人が検索にひっかかるようBioも含めていたのですが、Twitter自体のユーザ数・エントリ数が増えたことにより検索結果にノイズが混じるようになってきました。

またTwitter内でもちらほらと要望があったので(ありがとうございます;-))、今回のサーバ増強に合わせて追加しました。

テキストボックス下の「本文のみ」チェックボックスにチェックを入れて検索すると本文のみが検索対象となります。

このオプションはRSS出力でも有効ですので本文のみ購読したい方は「本文のみ」で検索した後に購読を行って下さい。

# あと前後しますが、サーバの増強を行いました。パフォーマンスが改善されたかと思います。;-)

PHP & 雑記 2007/05/25 02:38

第24回PHP勉強会に参加してきました。

第24回PHP勉強会

events.php.gr.jp

第24回PHP勉強会に参加してきました。詳細なレポートはshimookaさんのところにあるので;-)、ざっくりと感想を。

extensionがアツい!

最近はフレームワークに注力してたのであまり追いかけてなかったのですが、やはり動いているモノ(ミサイルw)を見ると引き込まれます。以前少しだけCを書いていた時期があるのでバイナリアン系のネタは聞いているだけで楽しいです。

既に完成しているライブラリをPHP化するなら、ネタも色々ありそうなので何かやってみたいですね。単純に「extension作れる=かっこいい」というのもありますし。;-)

携帯+PC連携

内容とは微妙に違いますが、前から思っていたのが「汎用テンプレートって無いのか?」ということ。PHPだろうがPerlだろうがPythonだろうがRubyだろうが・・・テンプレートエンジン使うんだったら同じ書式のテンプレートを使ったら良いのに。

開発者側はそれぞれ覚えれば良いですが、デザイン側にそれを押しつけることはできないので結局今いる環境から動けない、なんて人もいる気がします。(実際それで新しいものを取り入れるのを躊躇したり。)

たとえばSmartyで書いたテンプレートが他の言語でも使えるとかで良いわけです。(うーん作ってみたいな。。。)

見える化

まさに一見にしかずです。上手く説明できないですが、できたものを見るとなぜかわくわくします。自然と「おー」と声が出ます。何か上手く使ってみたいです。

ちょっと体調不良だったり、宿難民になったりでいろいろありましたが、参加して良かったです。

会社から言われたわけでなく、自分でわざわざこういった勉強会に参加される方は当たり前ですが学習意欲の高い方ばかりなわけです。そんな方々と自分の興味ある分野で、ああだこうだとお話できたら、楽しくないわけがない!!

日頃、開発は一人でやっているのでとても良い刺激を受けました。また近いうちに参加したいと思うのでよろしくお願いします。:-)

# Twitterで実況してましたが誰も見てない気がしてやめました:-p
# せっかくなんでいちおうログ出しときます。Twitter検索 : @phper

PHP & 雑記 2007/05/24 17:38

第24回PHP勉強会に参加してきます。

今からPHP勉強会に参加してきます。
shimookaさんがblogで実況されるとの事なので、私はTwitterで実況してみようと思います。

Twitterのアカウントはshin1x1です。

では参加される皆さんよろしくお願いします。

CakePHP & PHP 2007/05/11 22:24

CakePHP Controller#Object()が外部から呼べる

以前あったControllerのメソッドが外部から呼べてしまう問題ですが、フレームワークが修正されて問題は解決したと思っていました。

しかし、よくよく見てみるとObject()だけはまだ呼べる状態になっています。

下のようなコントローラに[http://example.com/hoge/Object]でアクセスすると"**construct"が2回表示されます。

[app/controller/hoge_controller.php]

PHP:
  1. <?php
  2. class HogeController extends AppController {
  3.   var $uses = array();
  4.  
  5.   function __construct() {
  6.     parent::__construct();
  7.     var_dump("**construct");
  8.   }
  9. }
  10. ?>

コンストラクタを継承してHogeControllerでややこしい事をしなければ、まあ2回呼ばれても良いかもしれませんが、やはり外から呼べる状態は気持ち悪いです。

こういうのを考えるとURLからコントローラとアクションが自動的にマッピングされるより、routes.phpできっちりマッピングしておいた方が安全かなあと思ったりします。(まあ利便性とのバランスですが)

いちおうチケットは出しておいたので修正されるのを待ちたいと思います。

PHP 2007/05/10 08:26

クエリ文字列のセッションIDはクッキーには出力されない

セッション固定化(Session fixation)を調べている時に気づいたのですが、PHPではクエリ文字列内のセッションIDはクッキーとしては出力されないんですね。

良くセッション固定化で例に挙げられるが下のような例です。

  1. 攻撃者がセッションID付きURL[http://example.com/?PHPSESSID=abcd]をユーザAに踏ませる
  2. ユーザAのセッションが[セッションID=abcd]で生成される。
  3. ユーザAがログインする。
  4. 攻撃者が[セッションID=abcd]でアクセスするとユーザAがログイン済みの状態になっており、セッションを乗っ取る事ができる。

これ自体はもちろんそうなのですが、PHPではクエリ文字列に含まれるセッションIDでセッションは生成されますが、クッキーにそのセッションIDは出力されません。(PHP5.2.1のext/session/session.cを見るとそんな感じの実装です。)

2.の状態ではサーバ上に[セッションID=abcd]のセッションは存在しますが、そのセッションIDはクライアント側には知らされません。

3.でログイン情報をクライアントからサーバにPOSTで送信しますが、クライアントは2.でセッションIDの通知を受けていないので、セッションIDは送信しません。なのでサーバ上では新規セッションとして新しいセッションIDが生成されます。

その後、4.のように攻撃者が[セッションID=abcd]でアクセスしても、ログイン前のセッション(空のセッション)を参照するだけなので、当然ながら要ログインな画面へはアクセスできません。

つまり単純にセッションID付きURLを踏ませても、認証セッションを乗っ取るのは難しいのかなと。(かといってセッション固定化対策が不要なわけでは無いのであしからず。)

※これはセッションIDの受け渡しにクッキーを使っている場合の話です。携帯のようにクエリ文字列でセッションIDの受け渡しを行う場合は、例の手順でセッションを乗っ取ることができます。

雑記 2007/05/06 11:16

Wiiリモコンが反応しない

Wiiを起動したところリモコンが反応しなくなったのでメモ。

症状はWii本体起動時から何を押してもリモコン下部のインジケータがちかちかするのみで画面は反応しないというもの。当然ながら画面にはカーソルが出てきません。

Googleで検索して、本体<->リモコンをSyncしたり、リモコンを手で叩いたりしてみたのですが改善せず。

で、見つけたのが↓

開発の当初は、蛍光灯の光に反応してしまうことがあったり、予想外のことがたくさんありました。蛍光灯や、太陽光に反応しにくくする仕組みというのは地味なところではありますけど、そうとう苦労したところです。

(任天堂総合開発本部 開発部 開発第5グループ 池田 昭夫 氏)

Wii 最大の敵は日光 - Engadget Japanese

夜だったんで日光は無いですが、念のため蛍光灯を切って本体<->リモコンをSyncすると無事解決しました。

Syncする時は蛍光灯を切るのが良いかと。

CakePHP & Webサービス & twitter 2007/05/03 00:05

Twitter検索がRSS対応になりました

既にお気付きかと思いますが、Twitter検索がRSS対応になりました。

キーワード検索の検索結果をお好きなRSSリーダーで見ることができます。

同じキーワードを定期的にチェックしたい方は活用してみてください。

↓のような使い方が面白いかも。

  • 自分のユーザ名で検索。
    =>自分宛に書いた投稿をチェック
  • 気になるキーワードで検索。
    =>キーワードに合致する投稿をチェック
  • でも検索結果が0。
    =>いつか誰かが書くかもしれないので、いちおうRSS購読(by @jazzanovaさん)

RSS対応の背中を押して下さった@nitoyonさん、@otuneさんありがとうございました。