PHPでサイトのルートパスを取得する方法

外部ファイルをincludeしたい場合に、絶対パスではなくて、サイトルートからのパスで取得したい場面に出くわしました。調べたら、PHPにはサイトのルートを返してくれる便利なものがあるんですね。

こいつで一発でした。

覚えておこうっと。

このページのトップに戻る
投稿日:2008/9/8  投稿者:go  コメント(0)

PHPのコード最適化

PHPのコード最適化のエントリがあったので軽く読んでみた。

たくさんありすぎてなんともいえませんが、意識するようにはしたいなぁ。

33. if (strlen($foo) < 5) を調べたいなら if (!isset($foo{5})) と書くと速い。

これは知らなかった。

20番ぐらいまでは割とよく使いそうな感じなのでメモ。

  1. static にできるメソッドは static として宣言しよう。(4倍速い)
  2. echo の方が print より速い。
  3. echo ‘文’,'字’; (カンマ区切り)の方が、’文’.'字’ (ドット連結)より速い。
  4. ループの最大値は、ループ「内」ではなく「前」にセットしておこう。
  5. 大きい配列のような変数は unset ()してメモリを解放しよう。
  6. マジックメソッド(例: __get, __set, __autoload)は使用を避けよう。
  7. require_once はハイコストなのです。
  8. include や require でファイルはフルパスで指定しよう。
  9. スクリプト開始時間は time() でなく $_SERVER[’REQUEST_TIME’] で取得。
  10. 可能であれば、正規表現より strncasecmp、strpbrk、stripos を使おう。
  11. strtr(str_replace の4倍速い) > str_replace > preg_replace の順に速い。
  12. 引数に配列、文字列両方を受け入れるような関数は避け、個別に関数化しよう。
  13. if をたくさん使ってるなら switch を活用しよう。(訳注:ってことでいい?)
  14. @によるエラー制御はすんごく遅い。
  15. Apache の mod_deflate(Apache2系) を ON にしておこう。(No.42 参照)
  16. 処理が終わったらデータベースの接続は切っておこう。
  17. $row[’id’] は $row[id] より7倍速い。
  18. エラーメッセージはハイコスト。
  19. for 文の条件式には count($array) のような関数をいれない。(変数に格納)
  20. メソッド内ではローカル変数をインクリメントするのが一番速い。

13が気になるなぁ。
switchはあんまり使わないからなぁ。

可読性が悪くならないようにうまいこと両立させていきたいな

このページのトップに戻る
投稿日:2008/5/23  投稿者:zuya  コメント(3)

PHPの定義済みの定数

すぐ忘れちゃうから、個人的に使うものをメモ

_FILE_
処理中のファイル名。

PHP_EOL
システムの改行コード(環境に依存)

DIRECTORY_SEPARATOR
 ディレクトリのセパレータ(環境に依存)

PATH_SEPARATOR
パスのセパレータ(環境に依存)

PHP_VERSION
phpのバージョンを取得できる

忘れないのが一番いいんだけどね

このページのトップに戻る
投稿日:2008/5/2  投稿者:zuya  コメント(0)

AWSをPHPでつかってみた

アマゾンのWebサービスを使ってみたかったので、試してみました。

まずこの英語のページからアカウントを取得するのですが、そこで物凄くつまずきました。

何が必須項目なのかわからないし、エラーメッセージも英語なのを抜きにしても何を入力して欲しいのかまったくわかりませんでした。

いろいろためして、最終的に電話番号と郵便番号に「-」をいれたら通りました。
意味がわからなかった。

とりあえず、書いて検索ワードをもらって1ページ目の情報を表示するようなサンプル。
エラー時の処理とかはまったく入れてないです。

とりあえず動いた。

こちらのサイトさんに詳しくのってました→ajaxtower

このページのトップに戻る
投稿日:2008/4/17  投稿者:zuya  コメント(0)

今まで使った画像のAPIのサンプルサイト

画像のAPIを使ったサンプルサイトを作ってみた。

検索ワードをいれると、フリッカーとYahooとフォト蔵APIの検索結果を表示してくれるだけ。

件数を絞ってないから異様に重いサイトになってしまった。

あと、なんとなくhighslide.jsを使ってみた。

これでとりあえすサムネイルを押すと拡大画像が表示された。

CSSをいじれば、見せ方をもっと変えれるらしい。

こちらのサイト様に詳しくのってました。

すごいJavaScriptだなぁ。

このページのトップに戻る
投稿日:2008/4/11  投稿者:zuya  コメント(0)