- 2010/04/29 MIT license , php

「PHP Excel Reader」はエクセルをPHPで読み込む事ができるライブラリです。
セルの値や書式を取得してPHPで扱う事が簡単にできるようになります。
cakephp/wordpress/flash/flex/iPhone/mixiアプリの開発しています。

「PHP Excel Reader」はエクセルをPHPで読み込む事ができるライブラリです。
セルの値や書式を取得してPHPで扱う事が簡単にできるようになります。
「osmplayer」というオープンソースで作られたメディアプレイヤーをご紹介。

自分用メモです。
CakePHPからDropBoxのファイルが操作できるコンポーネントが Bakeryにありました。
DropBoxってAPIなんてあったんですね。ログインして自分のファイルを操作できるようです。
これでサーバーでもファイルの同期ができそうです。
CakePHPに限らず、色んなサイトで流用できそうですね。

「Template Inheritance」はPHPで使えるテンプレート用のライブラリです。
ヘッダーやフッターの要素をincludeするかのように設定可能です。
プログラムは全てPHPコードで記述するため、テンプレート言語を学ぶ必要がないのが特徴です。
全体レイアウトを1ファイルで管理する際にSmartyを使うほどでも、、、な小規模サイトに良さそうです。
詳しくは以下

「SlimStat」はオープンソースでできたアクセス解析ソフトです。Google Analyticsのような解析ソフトを自前で構築する際(Analyticsが何かの理由で使えない場合)のためなどに、覚えておいても良いかもしれません。
詳しくは以下

執筆時のバージョン2.2.4
Phpnsは既存のサイトに簡単に組み込む事できるCMSです。通常CMSを使用する場合は独自のディレクトリ構造の中に公開ディレクトリがある場合が多いのですが、Phpnsは吐き出された1行のコードを読み込むだけでCMSが設置できるようになっています。
PHPなどに詳しく無い方でも簡単に設定できるのも魅力です。
詳しくは以下

APCはPHPの中間コードのキャッシュや最適化を行う拡張モジュールです。基本的にPHPを使うサーバーに全て入れてよいようです。
本日とあるサーバーにインストールしたのでやり方をメモ。
まずは環境ですが、CentOS 4.4 + PHP 5.1.6 です。
まず、peclが入っているかどうか調べます。
# pecl list-all apc All packages: ============= Package Latest Local pecl/KTaglib 0.2.0 Library to edit audio properties and tags on MPEG and OGG files pecl/FliteTTS Text to speech voice synthesis for PHP pecl/Ovrimos Ovrimos interface pecl/DTrace 1.0.3 A Solaris Dtrace provider pecl/inclued 0.1.0 Clued-in about your inclueds pecl/zookeeper 0.1.0 PHP extension for interfacing with Apache ZooKeeper … … … …
インストールされているパッケージが表示されれば、このSTEPは読み飛ばしてOKです。
なければインストールます。
# yum install -y php-pear Setting up Install Process Setting up repositories update 100% |=========================| 951 B 00:00 base 100% |=========================| 1.1 kB 00:00 … … …
phpizeもインストールします。
# yum install -y php-devel
apxsも無ければインストール
# yum install -y httpd-devel
これでやっとpeclがインストールできます。
peclコマンドでインストールできます。
# pecl install APC
無事にインストールが完了すると以下のようなメッセージがでます。
Build process completed successfully Installing '/var/tmp/pear-build-root/install-APC-3.0.19//usr/lib/php/modules/apc.so' install ok: channel://pecl.php.net/APC-3.0.19 You should add "extension=apc.so" to php.ini
ふむふむ。php.iniに追加しろって事ですね。
って事でphp.iniに以下の行を追加。場所はどこでもかまいません。
extension=apc.so
iniファイルを編集したらapacheを再起動します。
これでとりあえず作業は完了です。
phpinfoの画面でapcの項目があるか確認します。

apcのアップグレードは以下のコマンドで。
# pecl upgrade apc
ApacheBenchでどのくらい効果が変わったか測定します。
1000件のリクエストを100の同時接続で計測した結果です。
# ab -n 1000 -c 100 http://127.0.0.1/*****/test.php
Benchmarking 127.0.0.1 (be patient)
Completed 100 requests
Completed 200 requests
Completed 300 requests
Completed 400 requests
Completed 500 requests
Completed 600 requests
Completed 700 requests
Completed 800 requests
Completed 900 requests
Finished 1000 requests
Server Software: Apache/2.0.63
Server Hostname: 127.0.0.1
Document Path: /*****/test.php
Document Length: 1257 bytes
Concurrency Level: 100
Time taken for tests: 13.193656 seconds
Complete requests: 1000
Failed requests: 557
(Connect: 0, Length: 557, Exceptions: 0)
Write errors: 0
Total transferred: 1897728 bytes
HTML transferred: 1504335 bytes
Requests per second: 75.79 [#/sec] (mean)
Time per request: 1319.366 [ms] (mean)
Time per request: 13.194 [ms] (mean, across all concurrent requests)
Transfer rate: 140.45 [Kbytes/sec] received
Connection Times (ms)
min mean[+/-sd] median max
Connect: 0 5 17.9 0 80
Processing: 74 923 879.0 498 5931
Waiting: 56 919 880.2 497 5930
Total: 102 929 877.3 502 5931
Percentage of the requests served within a certain time (ms)
50% 502
66% 974
75% 1209
80% 1371
90% 2181
95% 2667
98% 3048
99% 4531
100% 5931 (longest request)
トータルで13秒でした。
ふーむ。早くなってるんですかね。念のためapcを無効にして再度ベンチを図ってみました。
# ab -n 1000 -c 100 http://127.0.0.1/*****/test.php
Benchmarking 127.0.0.1 (be patient)
Completed 100 requests
Completed 200 requests
Completed 300 requests
Completed 400 requests
Completed 500 requests
Completed 600 requests
Completed 700 requests
Completed 800 requests
Completed 900 requests
Finished 1000 requests
Server Software: Apache/2.0.63
Server Hostname: 127.0.0.1
Server Port: 80
Document Path: /*****/test.php
Document Length: 1257 bytes
Concurrency Level: 100
Time taken for tests: 32.801446 seconds
Complete requests: 1000
Failed requests: 3
(Connect: 0, Length: 3, Exceptions: 0)
Write errors: 0
Total transferred: 1651341 bytes
HTML transferred: 1258341 bytes
Requests per second: 30.49 [#/sec] (mean)
Time per request: 3280.145 [ms] (mean)
Time per request: 32.801 [ms] (mean, across all concurrent requests)
Transfer rate: 49.14 [Kbytes/sec] received
Connection Times (ms)
min mean[+/-sd] median max
Connect: 0 62 171.8 0 599
Processing: 288 2895 1431.8 2741 22702
Waiting: 8 2886 1441.0 2740 22701
Total: 616 2958 1410.4 2760 23294
Percentage of the requests served within a certain time (ms)
50% 2760
66% 2896
75% 2959
80% 2987
90% 3437
95% 4084
98% 6956
99% 9495
100% 23294 (longest request)
トータルで32秒でした。おお!19秒も違いますね。
まさか、倍以上違うとは、、、
まだ入れてない方はぜひ。
ちなみに高速化モジュールは他にも以下のようなものがあります。
今回はyumから入れたいという理由でAPCを採用しました。
導入にあたっては以下の記事を参考にさせていただきました。ありがとうございます。
APC(Alternative PHP Cache)再び – Do You PHP?
PHP(というかWordPress)高速化のためにAPC(Alternatice PHP Cache)入れた – IDEA*IDEA ~ 百式管理人のライフハックブログ
CakePHP1.2で管理者用の静的ページを作る(認証付き)というエントリーを見つけました。
静的ページで良いんだけど認証ユーザーにだけ見せたい場合とかってみんなどうやってるんでしょうね。自分のやり方を忘れないためにエントリー。
やり方としてはPagesにアクセスされた際にapp_controllerにて、ログインユーザー以外は非表示になるよう処理を振り分けます。
コードはこんな感じです。
<php
class AppController extends Controller {
var $lockedPages = array('agreement');
function beforeFilter()
{
// pages controllerかどうかをチェック
if ($this->name == 'Pages')
{
// pagesなら引数を受け取る
$path = $this->passedArgs;
// 認証ユーザーしか閲覧できないページか調べる
if (isset($path[0]) && in_array($path[0], $this->lockedPages))
{
//ここでpagesのdisplayをロック
$this->Auth->deny('display');
}
}
}
}?>
$lockedPagesに、認証ユーザーにだけ見せたいPageを配列で指定するだけで簡単に量産することが可能です。
これだとルーティングも特に変更する必要はありません。
どっかの記事にのってたのを参考にしたはずなんですが、元記事が見つけられませんでした。
pages_controllerをapp以下に持ってきた方が色々カスタマイズするには便利なんだけど、静的ページを見せたいだけならいっつもこんな感じです。

hide_emailはPHPでメールアドレスをソースから隠す関数です。
通常メールアドレスをそのままHTMLに記述してしまうとロボットなどにアドレスを収集され、ものすごいスパムの嵐を体験することになってしまいます。
この関数を使用すると、JavaScriptを生成し、ロボットなどがメールアドレスだと認識できないようにします。
以下のコードで実行可能なようです。
<php
echo hide_email('myadress@example.com');
function hide_email($email) {
$character_set = '+-.0123456789@ABCDEFGHIJKLMNOPQRSTUVWXYZ_abcdefghijklmnopqrstuvwxyz';
$key = str_shuffle($character_set); $cipher_text = ''; $id = 'e'.rand(1,999999999);
for ($i=0; $i<strlen($email); $i+=1) $cipher_text.= $key[strpos($character_set,$email[$i])];
$script = 'var a="'.$key.'";var b=a.split("").sort().join("");var c="'.$cipher_text.'";var d="";';
$script.= 'for(var e=0;e<c.length;e++)d+=b.charAt(a.indexOf(c.charAt(e)));';
$script.= 'document.getElementById("'.$id.'").innerHTML="<a href=\\"mailto:"+d+"\\">"+d+"</a>"';
$script = "eval(\"".str_replace(array("\\",'"'),array("\\\\",'\"'), $script)."\")";
$script = '<script type="text/javascript">/*<![CDATA[*/'.$script.'/*]]>*/</script>';
return '<span id="'.$id.'">[javascript protected email address]</span>'.$script;
}
?>
サイトにはJavaScriptを生成してくれるジェネレータもありますので、興味のある方は見てみてください。

jQueryでタブを動的に作成するチュートリアルDynamic tabs using jQuery – why and how to create it のご紹介。
jQueryでiGoogleのように自由にタブの追加や削除を行う事が可能になります。
実際のデモを見ていただくと動きがわかると思います。
以下のようなhtmlとJavaScriptを用意するだけで動作するようです。
<script>
$("#documents a").click(function() {
addTab($(this));
});
function addTab(link) {
// hide other tabs
$("#tabs li").removeClass("current");
$("#content p").hide();
// add new tab and related content
$("#tabs").append("
" + $(link).attr("title") + " "); // set the newly added tab as curren $("#" + $(link).attr("rel") + "_content").show(); } </script>
ダイナミックなページを作成したい方は、使ってみてはいかがでしょうか。
0