PHPのセッションのガーベジコレクションがよくわからない

PHPマニュアルに以下のようにあるんだけど、

http://jp.php.net/manual/ja/session.configuration.php#ini.session.save-path

オプションの引数としてN(数値)を指定できます。 これはセッションファイルを分散して保存する際に ディレクトリ階層レベルを決定します。 例えば、'5;/tmp'とすると /tmp/4/b/1/e/3/sess_4b1e384ad74619bd212e236e52a5a174If という位置にセッションファイルを生成します。 Nを使用するには、これらすべてのディレクトリが 事前に作成されている必要があります。 そのためのシェルスクリプトがext/sessionに mod_files.shというファイル名であります。 また、0以上のNが指定されている場合には自動ガーベッジコレクション が機能しないことに注意してください。詳細は php.ini を見てください。 また、Nを指定する場合は、 session.save_pathを"quotes"で囲う必要があります。 なぜならセパレータ(;) は php.ini ではコメントとしても利用されているからです。

これがちょっとまえのマニュアルだと、

http://www.teu.ac.jp/chiit/~dsuzuki/phpdoc/ref.session.html

session.save_pathのパスの深さが2より大きい場合、ガーベッジコレクションは行われません。

となっているぽい。

debianのパッケージから入れたphpでは、デフォルトのセッション保存先は /var/lib/php5 になってる。
これが「パスの深さが2より大きい場合」にあたるのか、自分が試した限りではセッションが破棄されなかった。

 
< ?php
ini_set('session.gc_maxlifetime', 3);
ini_set('session.gc_probability', 1);
ini_set('session.gc_divisor', 1);
session_cache_expire(1);
session_start();
session_regenerate_id();
 
if (isset($_SESSION['user'])) {
    $_SESSION['count'] += 1;
    echo 'login', $_SESSION['count'];
} else {
    $_SESSION['user'] = true;
    echo 'logout';
}
?>
 
<a href="test.php">session test</a>
 

/var/tmp とか /tmp に保存すると指定時間後に破棄されたけど、/var/lib/php5 だととりあえず今も残ってる。

php.session.gc

どうにかならないのかなこれ。

Zend_LoaderはPEARにも使える

ZendFrameworkのコンポーネントの1つ、Zend_LoaderはSPLのautoloadを実装したものです。

PHPファイルの頭で、

 
< ?php
require_once 'Hoge/Fuga/Uhya.php';
require_once 'Unko/Chinko/Pantsu.php';
require_once 'PEAR/Something/Ahya.php';
 

っていうふうに ファイルを1個ずつ呼び出して行くのはめんどくさ過ぎなので autoload を使う。

require_once を書く代わりに、

 
< ?php
require_once 'Zend/Loader.php';
Zend_Loader::registerAutoload();
 

って書いておけば、もう命名規則に沿っている限り require_once はもう書かなくて良い。

Zend_Loaderは中で、アンダーバーに 「 _ 」をスラッシュ「 / 」 に置き換えて他のファイルを読む込む必要がでてきたときに勝手にインクルードしてくれる。

 
< ?php
require_once 'Zend/Loader.php';
Zend_Loader::registerAutoload();
 
$dh = Date_Holidays::factory('Japan', 2008, 'ja_JP');
 
$date = new Date_Holidays();
 

とりあえずPEARは全部命名規則通りだったと思うので、もうrequire_once イラネ。

ZendFramework SQL Debug View Helper

cakeとかsymfonyには画面下にSQLログみたいなのが表示されてる。これzfにも欲しい。

と思ってポイものを作った。

svn co http://svn.coderepos.org/share/lang/php/ZendFramework_ext/library/Ex/View/Helper/ShowSQL.php

使い方。

bootstrapで、view helperのディレクトリを指定する。

 
$view = new Zend_View();
$view->addHelperPath(self::$root . '/library/Ex/View/Helper', 'Ex_View_Helper');
 

で、viewの中で

 
< ?php echo $this->showSQL() ?>
 

ってやると、

こんなやつが表示される。

helper内の

 
$this->_db = Zend_Db_Table::getDefaultAdapter();
 

DBに接続する部分は環境にあわせて書き換えてください。
このプラグイン内でjQueryを読み込んでて、それが影響するようならJSの部分だけ消しちゃってください。
テーブルのソートができなくなるぐらいで特に問題はないです。

plugin内で完結させようとしてHTMとかCSSがごちゃまぜになってしまった。

ZendFrameworkでニコりまくる。mylist編

前回 ZendFrameworkでニコる。flv。

mylist の動画を全部落とす。

連続でアクセスしまくるとしばらく(15分ぐらい?)弾かれるみたいなので、1つのflvダウンロードするごとに sleep(30) で30秒待機してます。

 
< ?php
require_once 'Zend/Loader.php';
Zend_Loader::registerAutoload();
 
// create adapter
$client = new Zend_Http_Client();
$client->setConfig(array('keepalive' => true));
 
// Login
$client->setCookieJar()
       ->setUri('https://secure.nicovideo.jp/secure/login?site=niconico')
       ->setParameterPost(array(
            'mail'     => 'mailaddress',
            'password' => 'password',
         ))
       ->request(Zend_Http_Client::POST);
 
// get mylist html
$list = 'http://www.nicovideo.jp/mylist/7446991';
$client->setUri($list)
       ->request(Zend_Http_Client::GET);
$response = $client->getLastResponse();
 
$html = $response->getBody();
 
// get smile video list
$dom = new Zend_Dom_Query($html);
$xpath = "//html/body/div[@id='PAGEBODY']/div[2]/table[@id='mylists']/tr/td[2]/h3/a";
$results = $dom->queryXpath($xpath);
 
// get href
$urlList = array();
foreach ($results as $r) {
    $urlList[] = $r->getAttribute('href');
}
 
// get flv
foreach ($urlList as $url) {
    $video = preg_split('/\//', $url);
    $video_id = $video[1];
 
    $client->setUri("http://www.nicovideo.jp/watch/{$video_id}")
           ->request(Zend_Http_Client::GET);
 
    // for filename
    $title = $client->getLastResponse();
 
    $client->setUri("http://www.nicovideo.jp/api/getflv?v={$video_id}")
           ->request(Zend_Http_Client::GET);
 
    $response = $client->getLastResponse();
 
    // get flv url
    $body = $response->getBody();
    parse_str($body, $query);
    $url = $query['url'];
 
    /**
     * get Title
     */
    $dom = new Zend_Dom_Query($title->getBody());
    $results = $dom->queryXpath('//title');
    foreach ($results as $r) {
        $pageTitle = $r->nodeValue;
    }
 
    /**
     * get flv
     */
    $client->setUri($url)
           ->request(Zend_Http_Client::GET);
    $response = $client->getLastResponse();
    file_put_contents("{$pageTitle}.flv", $response->getBody());
 
    sleep(30);
 
}
 

なんかたまに文字化けする。なんだかよくわからん。

ZendFrameworkでニコる。flv。

今さら。

flv取りたかった。

色々ハマった。(array)Object とか null とかに。

まぁいいや。

 
< ?php
require 'Zend/Loader.php';
Zend_Loader::registerAutoload();
 
$video_id = 'sm3997296';
 
// Create Adapter
$client = new Zend_Http_Client();
$client->setConfig(array('keepalive' => true));
 
// Login
$client->setCookieJar()
       ->setUri('https://secure.nicovideo.jp/secure/login?site=niconico')
       ->setParameterPost(array(
            'mail'     => 'mailaddress',
            'password' => 'password',
         ))
       ->request(Zend_Http_Client::POST);
 
$client->setUri("http://www.nicovideo.jp/watch/{$video_id}")
       ->request(Zend_Http_Client::GET);
 
// for filename
$title = $client->getLastResponse();
 
$client->setUri("http://www.nicovideo.jp/api/getflv?v={$video_id}")
       ->request(Zend_Http_Client::GET);
 
$response = $client->getLastResponse();
 
// get flv url
$body = $response->getBody();
parse_str($body, $query);
$url = $query['url'];
 
/**
 * get Title
 */
$dom = new Zend_Dom_Query($title->getBody());
$results = $dom->queryXpath('//title');
foreach ($results as $r) {
    $pageTitle = $r->nodeValue;
}
 
/**
 * get flv
 */
$client->setUri($url)
       ->request(Zend_Http_Client::GET);
$response = $client->getLastResponse();
file_put_contents("{$pageTitle}.flv", $response->getBody());
 

Zend_DomでHTMLのtitleタグ取得して、「title.flv」って名前で保存してます。ディレクトリに権限与えてください。

ほとんど http://puchiko.lowtech.ne.jp/?itemid=1071&catid=26 ここのまんまだけど。
PEAR::HTTP使ったことなくてちょっと時間かかった。Zend_Domも始めよくわからんかった。

たのし。