2008/11/08

貧乏環境でもデータベースが使いたい

自分でサーバを持てる金持ちには無縁な話(?)だが、PHPは魅力的だ。
こいつを動かしてくれる無料サーバがゴロゴロある。
ただ、レンタルサーバはあくまで他人様のもの。
好き勝手にはいじらせてもらえない。
そこで、どこまでだったらできるのか調べてみた。

まず無料サーバで、OracleやMySQLといったDBMSが提供されているということは期待できない。
念のためざらっと調べてみたが、やはりない。
それでもお金は払いたくない。

ここで諦めてはいけない。
PHPにはfwrite関数があるじゃないか!
ファイル出力さえできればデータの管理はどうにかなるはず。
XMLやCSVを利用すれば、それっぽくはなるはず。
幸いPHPには以下の便利な関数もある。
simplexml_load_file関数(XMLファイルをパースし、オブジェクトに代入する )
file(ファイル全体を読み込んで(一行ずつ)配列に格納する)

ただ、ここで注意しなくてはいけないのはファイルのパーミッションだ。
PHPから(データを管理する)外部ファイルを読み込む以上、そのファイルのパーミッションを他人からの参照不可にはできない。
誰でもファイルの中身を参照できてしまう。
この問題を解決するのに、以下の方法がある。

tablexml.php

<?php 
$xmlstr = <<<XML
<websites>
<website>
<title>Great Websites</title>
<characters>
<character>
<name>Google</name>
<url>http://www.google.co.jp/</url>
</character>
<character>
<name>Yahoo!</name>
<url>http://www.yahoo.co.jp/</url>
</character>
<character>
<name>はてな</name>
<url>http://www.hatena.ne.jp/</url>
</character>
</characters>
<plot>
There are Great Website.
</plot>
<success type="bestseller">4</success>
<success type="websiteclubs">9</success>
</website>
</websites>
XML;
?>

tablexml.php中のXMLからplot要素を取り出す。
<?php
include 'tablexml.php';

$xml = new SimpleXMLElement($xmlstr);
echo $xml->website[0]->plot; // " There are Great Website."
?>

XMLを文字列としてすべて$xmlstr代入し、そのオブジェクトを利用して処理。
(多くの言語がそうだろうが)PHPはブラウザから実行してもソースはダウンロードさせないため、容易にXMLの内容は参照できない。
これなら、うまくいきそうだ。

今度、SELECT文などのSQLのような、データベース操作言語(のような関数)を作ってみよう。 続き