NAME

TL - Tripletail, Framework for Japanese Web Application

NAME (ja)

TL - Tripletail, 日本語向けウェブアプリケーションフレームワーク

SYNOPSIS

use TL qw(tl.ini);

$TL->startCgi(
    -main => \&main,
);

sub main {
    my $t = $TL->newTemplate('index.html');

    $t->flush;
}

DESCRIPTION

use

tlでは、ライブラリの各種設定は Ini ファイルに置かれる。

実行が開始されるスクリプトの先頭で、次のように引数として Ini ファイルの位置を渡す。するとグローバル変数 $TL がエクスポートされる。 Ini ファイル指定は必須である。

use TL qw(/home/www/ini/tl.ini);

他のファイルから $TL 変数を使う場合は、そのパッケージ内で use TL; のように引数無しで use する。二度目以降の useIni ファイルの位置を指定しようとした場合はエラーとなる。

設定ファイルの設定値のうち、一部の値を特定のCGIで変更したい場合は、 次のように2つめ以降引数に特化指定をすることが出来る。

use TL qw(/home/www/ini/tl.ini golduser);

特化指定を行った場合、ライブラリ内で Ini ファイルを参照する際に、 まず「グループ名 + ":" + 特化指定値」のグループで検索を行う。 結果がなかった場合は、通常のグループ名の指定値が使用される。

また、サーバのIPやリモートのIPにより使用するグループを変更することも出来る。それぞれ 「グループ名 + "@sever" + 使用するサーバのマスク値」 「グループ名 + "@remote" + 使用するリモートのマスク値」 といった書式となる。

但し、スクリプトで起動した場合、リモートのIP指定している項目は全て無視される。 サーバのIP指定している項目の場合、hostname -iで取得した値でマッチされる。

使用するサーバのマスク値と、リモートのマスク値に関しては、Ini中の[HOST]グループに設定する。例えば次のようになる。

[HOST]
Debughost = 192.168.10.0/24
Testuser = 192.168.11.5 192.168.11.50
[TL@server:Debughost]
logdir = /home/tl/logs
errormail = tl@example.org
[TL@server:Debughost]
logdir = /home/tl/logs/regist

マスクは空白で区切って複数個指定する事が可能。

但し、[HOST]には特化指定は利用できない。

特化指定を二種、もしくは、三種を組み合わせて利用することも出来るが、その場合の順序は「グループ名 + ":" + 特化指定値 + "@sever" + 使用するサーバのマスク値 + "@remote" + 使用するリモートのマスク値」で固定であり、その他の並びで指定することは出来ない。

特化指定は複数行うことができ、その場合は最初の方に書いたものほど優先的に使用される。

特化指定

特化指定の具体的例を示す

[HOST]
Debughost = 192.168.10.0/24
Testuser = 192.168.11.5 192.168.11.50
[TL:regist@server:Debughost]
logdir = /home/tl/logs/regist/debug
[TL@server:Debughost]
logdir = /home/tl/logs
errormail = tl@example.org
[TL]
logdir = /home/tl/logs
[TL:regist]
logdir = /home/tl/logs/regist
[Debug@remote:Testuser]
enable_debug=1

というtl.iniが存在している場合に

use TL qw(/home/www/ini/tl.ini regist);
で、起動した場合、次のような動作になる。

プログラムが動いているサーバが、192.168.10.0/24であり、アクセスした箇所のIPが192.168.11.5か192.168.11.50である場合

[TL]
logdir = /home/tl/logs/regist/debug
errormail = tl@example.org
[Debug]
enable_debug=1

プログラムが動いているサーバが、192.168.10.0/24であり、アクセスした箇所のIPが192.168.11.5か192.168.11.50では無い場合

[TL]
logdir = /home/tl/logs/regist


use TL qw(/home/www/ini/tl.ini regist);
で、起動した場合、次のような動作になる。

プログラムが動いているサーバが、192.168.10.0/24であり、アクセスした箇所のIPが192.168.11.5か192.168.11.50である場合

[TL]
logdir = /home/tl/logs/debug
errormail = tl@example.org
[Debug]
enable_debug=1

プログラムが動いているサーバが、192.168.10.0/24であり、アクセスした箇所のIPが192.168.11.5か192.168.11.50では無い場合

[TL]
logdir = /home/tl/logs

キャッシュの利用

Cache::Memcachedがインストールされ、memcachedサーバがある場合に、キャッシュが利用可能となる。

具体例は次の通り

INIファイルにて、memcachedが動いているサーバを指定する。 [MemCached] servers = localhost:11211

読み込み側例(ページ全体をキャッシュ) #topはキャッシュするキー。画面毎にキーを設定する。ページャーなどを利用する場合、画面毎になる点を注意する(page-1等にする) #キャッシュにヒットした場合、時間を比較して、304でリダイレクトするか、メモリから読み込んで表示する #returnした後にprintやflushなど出力する操作は不可なため注意する事 return if(!defined($TL->printCacheUnlessModified('top'))); #キャッシュすることを宣言する。なお、宣言はprintCacheUnlessModifiedより後であれば、どの時点で行ってもかまわない $TL->setCache('top');
#実際のスクリプトを記述し、出力を行う

$TL->print('test code.');
書き込み側例(ページ全体をキャッシュ)
#書き込みを行った場合、そのデータを表示する可能性があるキャッシュを全て削除する
#削除漏れがあると、キャッシュしている内容が必要な為注意が必要。
$TL->deleteCache('top');
$TL->deleteCache('top2');
読み込み側例(ユーザー名等一部に固有の情報を埋め込んでいる場合) #クッキーデータの取得、クッキーに固有の情報を入れておくと高速に動作出来る(DB等から読み込みTL:Formクラスにセットしても可) my $cookiedata = $TL->getCookie->get('TLTEST'); $cookiedata->set('<&NAME>' => $name) if(!$cookiedata->exists('name')); $cookiedata->set('<&POINT>' => $point) if(!$cookiedata->exists('point'));
#topはキャッシュするキー。固有情報が変更された場合、キャッシュ情報をクリアしないと永遠に情報が変わらない為、
#304は通常無効にする必要がある。
#固有の情報を置換するための情報をセットする。キーがそのまま置換される。
#その他の条件はページ全体をキャッシュする場合と同様。
return if(!defined($TL->printCacheUnlessModified('top','off',$cookiedata)));
#キャッシュすることを宣言する。その際、固有の情報を置換するための情報をセットする。
$TL->setCache('top',$cookiedata);

#実際のスクリプトを記述し、出力を行う
#この際、固有の情報の部分に関しては、特殊タグ(文字列)に置換する。特殊タグはどのような形でもかまわないが、
#出力文字列中の全ての同様の特殊タグが変換対象になるため、ユーザーや管理者が任意に変更出来る部分に注意する。
#(タグエスケープする、その特殊タグが入力された場合エラーにするetc)

$t->expand(
  NAME => '<&NAME>',
  POINT => '<&POINT>',
);


$TL->print('test code.');
書き込み側例(ユーザー名等一部に固有の情報を埋め込んでいる場合)
#書き込みを行った場合、そのデータを表示する可能性があるキャッシュを全て削除する
#削除漏れがあると、キャッシュしている内容が必要な為注意が必要。
#また、固有の文字列を出力用にクッキーなどに書き出したりする。
$TL->getCookie->set(TLTEST => $TL->newForm('<&NAME>' => $CGI->get('name'),'<&POINT>' => 1000));

$TL->deleteCache('top');
$TL->deleteCache('top2');

実行モード

実行モードには次の三つがある。

CGIモード

CGIとしてプログラムを動作させるモード。このモードでは $TL->print メソッドや "出力フィルタ""入力フィルタ" が利用可能になる。

このモードでは $TL->startCgi メソッドで "Main関数" を呼ぶ。

FastCGIモード

FastCGIとしてプログラムを動作させるモード。httpdからfcgiスクリプトとして起動 しようとすると、自動的に選ばれる。このモードではプロセスのメモリ使用量を 監視し、起動後にある一定の大きさを越えてメモリ使用量が増大すると、メモリリーク が発生しているとして自動的に終了する。また、 Ini パラメータ付きで use TL したスクリプトファイルや、その Ini ファイルの最終更新時刻 も監視し、更新されていたら自動的に終了する。

一般スクリプトモード

CGIでない一般のスクリプトとしてプログラムを動作させるモード。 CGIモード特有の機能は利用出来ない。

このモードでは $TL->errorTrap メソッドで "Main関数" を呼ぶ。

出力フィルタ

$TL->print$template->flush で出力される内容は、 TL::Filter によって加工される。出力の先頭にHTTPヘッダを 付加するのも出力フィルタである。

入力フィルタ

$ENV{QUERY_STRING} その他のCGIのリクエスト情報は、 TL::InputFilter が読み取り、 TL::Form オブジェクトを生成する。得られたリクエスト情報は $CGI オブジェクトか $TL->CGI メソッドで取得出来る。

Main関数

リクエスト一回毎に呼ばれる関数。この関数の中でCGIプログラムは入出力を行う。 "FastCGIモード" 以外では一度のプロセスの起動で一度しか呼ばれない。

フック

$TL->setHook メソッドを用いてフックを掛ける事が出来る。

init

"startCgi" もしくは "errorTrap" が呼ばれ、最初に "Main関数" が 呼ばれる前。

preRequest

"Main関数" が呼ばれる直前。

postRequest

"Main関数" が呼ばれた直後。

term

最後に "Main関数" が呼ばれた後。termフック呼出し後に "startCgi" もしくは "errorTrap" が終了する。

METHODS

INI
$TL->INI

use TL qw(filename.ini); で読み込まれた TL::Ini を返す。

CGI
$TL->CGI
$CGI

リクエストを受け取った TL::Form オブジェクトを返す。 また、このオブジェクトは startCgi メソッドの呼び出し元パッケージに export される。

このメソッドがundefでない値を返すのは、 "preRequest" フックが呼ばれる 直前から "postRequest" フックが呼ばれた直後までである。

escapeTag
$result = $TL->escapeTag($value)

&<>"' の文字をエスケープ処理した文字列を返す。

unescapeTag
$result = $TL->unescapeTag($value)

&<>"'&#??;&#x??; にエスケープ処理された文字を元に戻した文字列を返す。

escapeJs
$result = $TL->escapeJs($value)

'"\ の文字を \ を付けてエスケープし,'\r' '\n' について '\\r' '\\n' に置き換える。

unescapeJs
$result = $TL->unescapeJs($value)

escapeJs した文字列を元に戻す。

encodeURL
$result = $TL->encodeURL($value)

文字列をURLエンコードした結果を返す。

decodeURL
$result = decodeURL($value)

URLエンコードを解除し元に戻した文字列を返す。

escapeSqlLike
$result = $TL->escapeSqlLike($value)

% _ \ の文字を \ でエスケープ処理した文字列を返す。

unescapeSqlLike
$result = $TL->unescapeSqlLike($value)

\% \_ \\ にエスケープ処理された文字を元に戻した文字列を返す。

startCgi
$TL->startCgi(
  -main        => \&Main,    # メイン関数
  -DB          => 'DB',      # DBを使う場合,iniのグループ名を指定
  -Session => 'Session',     # Sessionを使う場合、iniのグループ名を指定
);

CGIを実行する為の環境を整えた上で、 "Main関数" を実行する。 "Main関数" がdieした場合は、エラー表示HTMLが出力される。

DB は、次のように配列へのリファレンスを渡す事で、複数指定可能。

$TL->startCgi(
  -main => \&Main,
  -DB   => ['DB1', 'DB2'],
);

Session は、次のように配列へのリファレンスを渡す事で、複数指定可能。

$TL->startCgi(
  -main        => \&Main,
  -DB          => 'DB',
  -Session => ['Session1', 'Session2'],
);
errorTrap
$TL->errorTrap(
  -main => \&Main, # メイン関数
  -DB   => 'DB',   # DBを使う場合,iniのグループ名を指定
);

環境を整え、 "Main関数" を実行する。 "Main関数" がdieした場合は、エラー内容が標準エラーへ出力される。

"startCgi" と同様に、DB には配列へのリファレンスを渡す事も出来る。

dispatch
$result = $TL->dispatch($value, default => $default, onerror => \&Error)

'Do' と $value を繋げた関数名の関数を呼び出す。 $valueがundefの場合、defaultを指定していた場合、defaultに設定される。

onerrorが未設定で関数が存在しなければ undef、存在すれば1を返す。

onerrorが設定されていた場合、関数が存在しなければ onerrorで設定された関数が呼び出される。

例:
package Foo;

sub main {
    my $what = 'Foo';
    $TL->dispatch($what, default => 'Foo', onerror => \&DoError);
}

sub DoFoo {
    ...
}

sub DoError {
    ...
}
log
$TL->log($group => $log)

ログを記録する。グループとログデータの2つを受け取る。

setHook
$TL->setHook($type, $priority, \&func)

指定タイプの指定プライオリティのフックを設定する。 既に同一タイプで同一プライオリティのフックが設定されていた場合、 古いフックの設定は解除される。

typeは、"init", "term", "preRequest", "postRequest" の4種類が存在する。

なお、1万の整数倍のプライオリティは Tripletail 内部で使用される。アプリ ケーション側で不用意に用いるとフックを上書きしてしまう可能性があるので 注意する。

removeHook
$TL->removeHook($type, $priority)

指定タイプの指定プライオリティのフックを削除する。

setContentFilter
$TL->setContentFilter($classname, %option)
$TL->setContentFilter([$classname, $priority], %option)
$TL->setContentFilter('TL::Filter::HTML', charset => 'Shift_JIS')
$TL->setContentFilter(
    'TL::Filter::CSV', charset => 'Shift_JIS', filename => 'テストデータ.csv')

"出力フィルタ" を設定する。 全ての出力の前に実行する必要がある。 2番目の書式では、プライオリティを指定して独自のコンテンツフィルタを追加できる。 省略時は優先度は1000となる。同一優先度のフィルタが既にセットされているときは、 以前のフィルタ設定は解除される。

返される値は、指定された TL::Filter のサブクラスのインスタンスである。

設定したフィルタは、"preRequest" のタイミングで保存され、 "postRequest" のタイミングで元に戻される。従って、"Main関数"内 で setContentFilter を実行した場合、その変更は次回リクエスト時に持ち越 されない。

getContentFilter
$TL->getContentFilter($priority)

指定されたプライオリティのフィルタを取得する。省略時は1000となる。

removeContentFilter
$TL->removeContentFilter($priority)

指定されたプライオリティのフィルタを削除する。省略時は1000となる。 フィルタが1つもない場合は、致命的エラーとなり出力関数は使用できなくなる。

setInputFilter
$TL->setInputFilter($classname, %option)
$TL->setInputFilter([$classname, $priority], %option)

"入力フィルタ" を設定する。 "startCgi" の前に実行する必要がある。

返される値は、指定された TL::InputFilter のサブクラスのインスタンスである。

getInputFilter
$TL->getInputFilter($priority)
removeInputFilter
$TL->removeInputFilter($priority)
sendError
$TL->sendError(-title => "タイトル", -error => "エラー")

ini で指定されたアドレスにエラーメールを送る。 設定が無い場合は何もしない。

print
$TL->print($str)

コンテンツデータを出力する。"startCgi" から呼ばれた "Main関数" 内 のみで使用できる。ヘッダは出力できない。

フィルタによってはバッファリングされる場合もあるが、 基本的にはバッファリングされない。

location
$TL->location('http://example.org/')

CGIモードの時、指定されたURLへリダイレクトする。 このメソッドはあらゆる出力の前に呼ばなくてはならない。

parsePeriod
$TL->parsePeriod('10hour 30min')

時間指定文字列を秒数に変換する。 "度量衡" を参照。

parseQuantity
$TL->parseQuantity('100mi 50ki')

量指定文字列を元の数に変換する。 "度量衡" を参照。

getCookie

TL::Cookie オブジェクトを取得。

getCsv

TL::CSV オブジェクトを取得。

newDateTime

TL::DateTime オブジェクトを作成。

getDB
$DB = $TL->getDB($group)

TL::DB オブジェクトを取得。

newDB
$DB = $TL->newDB($group)

TL::DB オブジェクトを作成。

getFileSentinel

TL::FileSentinel オブジェクトを取得。

newForm

TL::Form オブジェクトを作成。

newHtmlFilter

TL::HtmlFilter オブジェクトを作成。

newHtmlMail

TL::HtmlMail オブジェクトを作成。

newIni

TL::Ini オブジェクトを作成。

newMail

TL::Mail オブジェクトを作成。

getMemorySentinel

TL::MemorySentinel オブジェクトを取得。

newPager

TL::Pager オブジェクトを作成。

getRawCookie

TL::RawCookie オブジェクトを取得。

newSendmail

TL::Sendmail オブジェクトを作成。

newSMIME

TL::SMIME オブジェクトを作成。

newTagCheck

TL::TagCheck オブジェクトを作成。

newTemplate

TL::Template オブジェクトを作成。

getSession

TL::Session オブジェクトを取得。

newValue

TL::Value オブジェクトを作成。

newValidator

TL::Validator オブジェクトを生成。

newMemCached

TL::MemCached オブジェクトを生成。

charconv
$str = $TL->charconv($str, $from, $to, $prefer_encode);
$str = $TL->charconv($str, [$from1, $from2, ...], $to, $prefer_encode);

$str = $TL->charconv($str, 'auto' => 'UTF-8');
$str = $TL->charconv($str, ['EUC-JP', 'Shift_JIS'] => 'UTF-8');

文字コード変換を行う。 Encode が利用可能、且つ $prefer_encode が 真である場合は、 Encode が用いられる。そうでない場合は Unicode::Japanese が用いられる。

Encode 使用時、変換元文字コードに 'auto' を指定すると、 Unicode::Japanesegetcode() と同じ優先順位で文字コードを自動判別する。また、エンコード名の候補を 配列で指定すると、指定された優先順位で自動判別する。

Unicode::Japanese 使用時に配列で候補を指定した場合は、その配列が無視され、 'auto' が指定されたものと見做される。

$from が省略された場合は 'auto' に、 $to が省略された場合は 'UTF-8' になる。

確実に指定できる文字コードは、UTF-8,Shift_JIS,EUC-JP,ISO-2022-JP である。 それ以外の場合は、EncodeUnicode::Japanese のどちらが使用されるかにより使用できるものが異なる。

readFile
$data = $TL->readFile($fpath);

ファイルを読み込む。文字コード変換をしない。 ファイルロック処理は行わないので、使用の際には注意が必要。

readTextFile
$data = $TL->readTextFile($fpath, $coding, $prefer_encode);

ファイルを読み込み、UTF-8に変換する。 ファイルロック処理は行わないので、使用の際には注意が必要。

$coding が省略された場合は 'auto' となる。$prefer_encode を真 にすると Encode が利用可能な場合は Encode で変換する。

writeFile
$TL->writeFile($fpath, $fdata, $fmode);

ファイルにデータを書き込む。文字コード変換をしない。 ファイルロック処理は行わないので、使用の際には注意が必要。

$fmode が0ならば、上書きモード。 $fmode が1ならば、追加モード。

省略された場合は上書きモードとなる。

writeTextFile
$TL->writeTextFile($fpath, $fdata, $fmode, $coding, $prefer_encode);

ファイルにデータを書き込む。$fdata をUTF-8と見なし、指定された文字コードへ変換を行う。 ファイルロック処理は行わないので、使用の際には注意が必要。

$fmode が0ならば、上書きモード。 $fmode が1ならば、追加モード。

省略された場合は上書きモードとなる。

$coding が省略された場合、utf8として扱う。$prefer_encode を真にする と Encode が利用可能な場合は Encode で変換する。

watch
$TL->watch(sdata => \$sdata, $reclevel);
$TL->watch(adata => \@adata, $reclevel);
$TL->watch(hdata => \%hdata, $reclevel);

指定したスカラー、配列、ハッシュデータの更新をウォッチし、ログに出力する。 第1引数で変数名を、第2引数で対象変数へのリファレンスを渡す。

第2引数はウォッチ対象の変数に、リファレンスが渡された場合に、 そのリファレンスの先を何段階ウォッチするかを指定する。デフォルトは0。

スカラー、配列、ハッシュ以外のリファレンスが代入された場合はエラーとなる。

また、再帰的にウォッチする場合、変数名は親の変数名を利用して自動的に設定される。

dump
$TL->dump(DATA => \$data);
$TL->dump(DATA => \$data, $level);

第2引数に変数へのリファレンスを渡すと,その内容を Data::Dumper でダンプし、 第1引数のグループ名で $TL->log を呼び出す。

第3引数で、リファレンスをどのくらいの深さまで追うかを指定することが出来る。 指定しなければ全て表示される。

printCacheUnlessModified
$bool = $TL->printCacheUnlessModified($key, $flag, $param, $charset)

第1引数で割り当てられたキーがメモリ上にキャッシュされているかを調べる。 利用するには、memcached が必須となる。

第2引数がonの場合、304を返す動作を行う。offの場合、304を返す動作を行わない。省略可能。

デフォルトはon。

第3引数では、TL::Form クラスのインスタンスを指定する。 Formクラスのキーが出力文字列中に存在している場合、値に置換する。省略可能。

第4引数では、第3引数で指定した文字列をUTF-8から変換する際の文字コードを指定する。 省略可能。

使用可能なコードは次の通り。 UTF-8,Shift_JIS,EUC-JP,ISO-2022-JP

デフォルトはShift_JIS。

第2引数がonの場合で、第3引数が省略された場合、以下の動作を行う。

1.memcachedからキーに割り当てられたキャッシュデータを読み込む。 データが無ければ、1を返す。

2.キャッシュデータの保存された時間と前回アクセスされた時間を比較し、 キャッシュデータが新しければキャッシュデータを出力し、undefを返す。

3.アクセスされた時間が新しければ、304ステータスを出力し、undefを返す。

この関数からundefを返された場合、以後出力を行う操作を行ってはならない。

setCache
$TL->setCache($key, $param, $charset, $priority)

第1引数で割り当てられたキーに対して出力される内容をメモリ上にキャッシュする。 また、Last-Modifiedヘッダを出力する。 printCacheUnlessModifiedより後で実行する必要がある。 利用するには、memcached が必須となる。

第2引数では、TL::Form クラスのインスタンスを指定する。 Formクラスのキーが出力文字列中に存在している場合、値に置換する。省略可能。

第3引数では、第2引数で指定した文字列をUTF-8から変換する際の文字コードを指定する。 省略可能。

使用可能なコードは次の通り。 UTF-8,Shift_JIS,EUC-JP,ISO-2022-JP

デフォルトはShift_JIS。

第4引数には、TL::Filter::MemCachedへの優先度を記述する。省略可能。 デフォルトは1500。

TL::Filter::MemCachedは必ず最後に実行する必要性があるため、 1500以上の優先度で設定するフィルタが他にある場合は手動で設定する必要がある。

deleteCache
$TL->deleteCache($key)

第1引数で割り当てられたキーのキャッシュを削除する。 利用するには、memcached が必須となる。

なお、setCacheの後にdeleteCacheを実行しても、setCacheでのメモリへの書き込みは、 処理の最後に行われるので、deleteCacheは反映されない。

本関数の使い方としては、キャッシュの内容を含んでいるデータを更新した場合に 該当するキャッシュを削除するように使用する。 それにより、次回アクセス時に最新の情報が出力される。

getDebug
newError

内部用メソッド。

Ini パラメータ

グループ名は常に TL でなければならない。

例:

[TL]
logdir = /home/www/cgilog/
errortemplate = /home/www/error.html
maxrequestsize
maxrequestsize = 16M 500K

最大リクエストサイズ。但しファイルアップロードの分を除く。デフォルトは8M。

maxfilesize
maxfilesize = 100M

一回のPOSTでアップロード可能なファイルサイズの合計。デフォルトは8M。ファ イルのサイズは maxrequestsize とは別にカウントされ、ファイルでないもの については maxrequestsize の値が使われる。

logdir
logdir = /home/www/cgilog/

ログの出力ディレクトリ。

tempdir
tempdir = /tmp

一時ファイルを置くディレクトリ。このパラメータの指定が無い時、アップロー ドされたファイルは全てメモリ上に置かれるが、指定があった場合は指定され たディレクトリに一時ファイルとして置かれる。一時ファイルを作る際には、 ファイルを open した直後に unlink する為、アプリケーション側でファイル ハンドルを閉じたりプロセスを終了したりすると、作られた一時ファイルは直 ちに自動で削除される。

errormail
errormail = null@example.org%Sendmail

sendErrorや、エラー発生時にメールを送る先を指定する。 アカウント名@ドメイン名%inigroup、の形式で指定する。 inigroupに。 TL::Sendmail クラスで使用するinigroupを指定する。 inigroupが省略されると 'Sendmail' が使われる。

errormailtype
errormailtype = error file-update memory-leak

どのような事象が発生した時に errormail で指定された先にメールを送るか。 以下の項目をスペース区切りで任意の数だけ指定する。 デフォルトは 'error memory-leak' である。

error

エラーが発生した時にメールを送る。 メールの内容にはスタックトレース等が含まれる。

file-update

TL::FileSentinel が監視対象のファイルの更新を検出した時にメールを送る。 メールの内容には更新されたファイルやその更新時刻が含まれる。

memory-leak

TL::MemorySentinel がメモリリークの可能性を検出した時にメールを送る。 メールの内容にはメモリの使用状況が含まれる。

errorlog
errorlog = 1

エラー発生時にログに情報を残すかどうかを指定する。 1 が指定されればエラー情報を残す。 2 が指定されれば、エラー情報に加え、CGIのリクエスト内容も残す(startCgi内でのエラーのみ)。 3 が指定されれば、ローカル変数内容を含んだ詳細なエラー情報に加えて(但し PadWalker が必要)、CGIのリクエスト内容も残す。 0 であれば情報を残さない。 デフォルトは 1。

memorylog
memorylog = full

リクエスト毎にメモリ消費状況をログに残すかどうかを指定する。 'leak', 'full' のどちらかから選ぶ。 'leak' の場合は、メモリリークが検出された場合のみログに残す。 'full' の場合は、メモリリークの検出とは無関係に、リクエスト毎にログに残す。 デフォルトは 'leak'。

trap
trap = die

エラー処理の種類。'none', 'die','diewithprint' から選ぶ。デフォルトは'die'。

none

エラートラップを一切しない。

die

"Main関数" がdieした場合にエラー表示。それ以外の場所ではトラップしない。warnは見逃す。

diewithprint

"Main関数" がdieした場合にエラー表示。"Main関数" 以外でdieした場合は、ヘッダと共にエラー内容をテキストで表示する。warnは見逃す。

stacktrace
stacktrace = full

エラー発生時に表示するスタックトレースの種類。'none' の場合は、スタック トレースを一切表示しない。'onlystack' の場合は、スタックトレースのみを 表示する。'full' の場合は、スタックトレースに加えてソースコード本体並び に各フレームに於けるローカル変数の一覧をも表示する。デフォルトは 'onlystack'。

但しローカル変数一覧を表示するには PadWalker がインストールされてい なければならない。

注意: 'full' の状態では、stackallow で許された全てのユーザーが、 ブラウザから全てのソースコード及び ini ファイルの中身を読む事が出来る点に注意すること。

stackallow
stackallow = 192.168.0.0/24

stacktrace の値が 'none' でない場合であっても、stackallow で指定された ネットマスクに該当しない IP からの接続である場合には、スタックトレース を表示しない。マスクは空白で区切って複数個指定する事が可能。 デフォルトは全て禁止。

maxrequestcount
maxrequestcount = 100

FastCGIモード時に、1つのプロセスで何回まで処理を行うかを設定する。 0を設定すれば回数によってプロセスが終了することはない。 デフォルトは0。

errortemplate
errortemplate = /home/www/error.html

エラー発生時に、通常のエラー表示ではなく、指定された テンプレートファイルを表示する。

outputbuffering
outputbuffering = 0

startCgi メソッド中で出力をバッファリングする。デフォルトは0。

バッファリングしない場合、print した内容はすぐに表示されるが、少しでも表示を行った後にエラーが発生した場合は、エラーテンプレートが綺麗に表示されない。

バッファリングを行った場合、print した内容はリクエスト終了時まで表示されないが、処理中にエラーが発生した場合、出力内容は破棄され,エラーテンプレートの内容に差し替えられる。

度量衡

時間指定

各種タイムアウト時間,セッションのexpiresなど、 時間間隔は以下の指定が可能とする。

単位は大文字小文字を区別しない。

数値のみ

秒数での指定を表す。

数値+ 'sec' or 'second' or 'seconds'

秒での指定を表す。[×1]

数値+ 'min' or 'minute' or 'minutes'

分での指定を表す。[×60]

数値+ 'hour' or 'hours'

時間での指定を表す。[×3600]

数値+ 'day' or 'days'

日数での指定を表す。[×24*3600]

数値+ 'mon' or 'month' or 'months'

月での指定を表す。1月=30日として計算する。 [×30*24*3600]

量指定

メモリサイズ、文字列サイズ等、大きさを指定する場合には、 以下の指定が可能とする。英字の大文字小文字は同一視する。

10進数系

数値のみ

そのままの数を表す。

数値+ 'k'

数値×1000の指定を表す。[×1,000]

数値+ 'm'

数値×1000^2の指定を表す。[×1,000,000=×1,000^2]

数値+ 'g'

数値×1000^3の指定を表す。[×1,000,000,000=×1,000^3]

数値+ 't'

数値×1000^4の指定を表す。[×1,000,000,000,000=×1,000^4]

数値+ 'p'

数値×1000^5の指定を表す。[×1,000,000,000,000,000=×1,000^5]

数値+ 'e'

数値×1000^6の指定を表す。[×1,000,000,000,000,000,000=×1,000^6]

2進数系

数値+ 'Ki'

数値×1024の指定を表す。[×1024=2^10]

数値+ 'Mi'

数値×1024^2の指定を表す。[×1024^2=2^20]

数値+ 'Gi'

数値×1024^3の指定を表す。[×1024^3=2^30]

数値+ 'Ti'

数値×1024^4の指定を表す。[×1024^4=2^40]

数値+ 'Pi'

数値×1024^5の指定を表す。[×1024^5=2^50]

数値+ 'Ei'

数値×1024^6の指定を表す。[×1024^6=2^60]

SEE ALSO

TL::Cookie
TL::DB
TL::Debug

CGI向けデバッグ機能。

リクエストや応答のログ記録、デバッグ情報のポップアップ表示、他。

TL::Filter
TL::FileSentinel
TL::Form
TL::HtmlFilter
TL::HtmlMail
TL::Ini
TL::InputFilter
TL::Mail
TL::MemorySentinel
TL::Pager
TL::RawCookie
TL::Sendmail
TL::SMIME
TL::TagCheck
TL::Template
TL::Session
TL::Value
TL::Validator

AUTHOR INFORMATION

    Copyright 2006 YMIRLINK Inc. All Rights Reserved.

    This framework is free software; you can redistribute it and/or modify it under the same terms as Perl itself

    このフレームワークはフリーソフトウェアです。あなたは Perl と同じライセンスの 元で再配布及び変更を行うことが出来ます。

    Address bug reports and comments to: tl@tripletail.jp

    HP : http://tripletail.jp/