#!/usr/bin/perl
# 定義
@DBs =
( # Iteration of the parameters
{
DB => 'db1_name', # Database Name
USERNAME => 'db1_username', # Username
PASSWORD => 'db1_password', # Password
},
{
DB => 'db2_name', # Database Name
USERNAME => 'db2_username', # Username
PASSWORD => 'db2_password', # Password
}
);
# アクセス
foreach my $db ( @DBs ) {
print "DB name : $db->{DB}\n";
print "Username: $db->{USERNAME}\n";
print "Password: $db->{PASSWORD}\n";
print "\n";
}
#!/usr/bin/perl
# 定義
@DBs =
( # Iteration of the parameters
{
DB => 'db1_name', # Database Name
USERNAME => 'db1_username', # Username
PASSWORD => 'db1_password', # Password
},
{
DB => 'db2_name', # Database Name
USERNAME => 'db2_username', # Username
PASSWORD => 'db2_password', # Password
}
);
# アクセス
foreach my $db ( @DBs ) {
print "DB name : $db->{DB}\n";
print "Username: $db->{USERNAME}\n";
print "Password: $db->{PASSWORD}\n";
print "\n";
}
use DBI; use Apache::Session;このモジュールは永続ストレージ (要はセッション情報をずっと溜めておけるデータベース) の種類によっていろいろな種類がある。
Apache::Session::MySQL Apache::Session::Postgres Apache::Session::File Apache::Session::Oracle Apache::Session::Sybase Apache::Session::DB_File Apache::Session::Flex 実行時にすべてのパラメータを指定する以下の例では Apache::Session::Flex を使っている。
use DBI;
use Apache::Session::Flex;
$session = _getSession;
print $session->{_sessin_id}
sub _getSession {
my $db;
my ($database, $username, $password);
# 以上の変数には値を入れること。
$db = DBI->connect("DBI:mysql:$databasename",
$username,
$password
) || die 'Cannot connect db';
eval {
tie %session, 'Apache::Session::Flex', $sid, {
Store => 'MySQL',
Lock => 'MySQL',
Generate => 'MD5',
IDLength => 32,
Serialize => 'Storable',
Handle => $db,
LockHandle => $db,
};
}; # セミコロンを忘れないこと
if($@) { # $@: error message of eval
return undef;
}
# セッション ID の取得に成功。ここに処理を書く。
return \%session;
}
use DBI; use Apache::Session;このモジュールは永続ストレージ (要はセッション情報をずっと溜めておけるデータベース) の種類によっていろいろな種類がある。
Apache::Session::MySQL Apache::Session::Postgres Apache::Session::File Apache::Session::Oracle Apache::Session::Sybase Apache::Session::DB_File Apache::Session::Flex 実行時にすべてのパラメータを指定する以下の例では Apache::Session::Flex を使っている。
use DBI;
use Apache::Session::Flex;
$session = _getSession;
print $session->{_sessin_id}
sub _getSession {
my $db;
my ($database, $username, $password);
# 以上の変数には値を入れること。
$db = DBI->connect("DBI:mysql:$databasename",
$username,
$password
) || die 'Cannot connect db';
eval {
tie %session, 'Apache::Session::Flex', $sid, {
Store => 'MySQL',
Lock => 'MySQL',
Generate => 'MD5',
IDLength => 32,
Serialize => 'Storable',
Handle => $db,
LockHandle => $db,
};
}; # セミコロンを忘れないこと
if($@) { # $@: error message of eval
return undef;
}
# セッション ID の取得に成功。ここに処理を書く。
return \%session;
}
CGI::Application は HTML::Template を統合している。以下は HTML::Template のドキュメントで書かれている例が含まれている。
使用するモジュール
use CGI::Application; # 要 HTML::Template # IPC::SharedCache (こちらは任意)
まずは以下のようなディレクトリとファイル構成にする。
./cgi-bin/lib/App.pm ./cgi-bin/templates/test.templ ./cgi-bin/index.cgi
index.cgi の内容:
基本的に App クラスを new して app->run() としているだけである。
BEGIN ブロックのそれはライブラリへのパスを探している。
#!/usr/bin/perl -w
use strict;
my $LIB_DIR;
BEGIN {
if ($0 =~ m!(.*[/¥¥])!) {
$LIB_DIR = $1;
} else {
$LIB_DIR = './';
}
unshift @INC, $LIB_DIR . 'lib';
}
use App;
my $app = App->new();
$app->run();
1;
App.pm の内容。
#!/usr/bin/perl -w
package App;
use strict;
use base 'CGI::Application';
sub setup {
my $self = shift;
$self->mode_param('rm');
$self->start_mode('start');
$self->run_modes(
'start' => ¥&start,
'end' => ¥&end
);
$self->header_props(-type=>'text/html', -charset=>'utf-8');
}
sub teardown {
my $self = shift;
# Post-response shutdown functions
# ここにはデータベースの切断を書くとよい。
}
sub start {
my $self = shift;
my $template = $self->load_tmpl('test.tmpl', die_on_bad_params => 0,
path => ['......./cgi-bin/templates'],
# cache => 1,
# double_cache => 1,
# file_cache => 1,
# file_cache_dir => '/tmp',
# double_file_cache => 1
);
return &template($template);
}
sub end {
}
sub template {
my $template = shift;
# the fruit data - the keys are the fruit names and the values are
# pairs of color and shape contained in anonymous arrays
my %fruit_data = (
Apple => ['Red, Green or Yellow', 'Round' ],
Orange => ['Orange' , 'Round' ],
Pear => ['Green or Red' , 'Pear-Shaped'],
Banana => ['Yellow' , 'Curved' ],
);
my @loop; # the loop data will be put in here
# fill in the loop, sorted by fruit name
foreach my $name (sort keys %fruit_data) {
# get the color and shape from the data hash
my ($color, $shape) = @{$fruit_data{$name}};
# make a new row for this fruit - the keys are <TMPL_VAR> names
# and the values are the values to fill in the template.
my %row = (
name => $name,
color => $color,
shape => $shape
);
# put this row into the loop by reference
push(@loop, \%row);
}
# call param to fill in the loop with the loop data by reference.
$template->param(fruit_loop => \@loop);
# print the template
return $template->output;
}
1;
test.tmpl の内容:
<HTML>
<HEAD>
<TITLE>Fruity Data</TITLE>
</HEAD>
<BODY>
<H1>Fruity Data</H1>
<TABLE BORDER=1>
<TR>
<TD><B>Fruit Name</B></TD>
<TD><B>Color</B></TD>
<TD><B>Shape</B></TD>
</TR>
<TMPL_LOOP NAME="fruit_loop">
<TR>
<TD><TMPL_VAR NAME="name"></TD>
<TD><TMPL_VAR NAME="color"></TD>
<TD><TMPL_VAR NAME="shape"></TD>
</TR>
</TMPL_LOOP>
</TABLE>
</BODY>
</HTML>
CGI::Application は HTML::Template を統合している。以下は HTML::Template のドキュメントで書かれている例が含まれている。
使用するモジュール
use CGI::Application; # 要 HTML::Template # IPC::SharedCache (こちらは任意)
まずは以下のようなディレクトリとファイル構成にする。
./cgi-bin/lib/App.pm ./cgi-bin/templates/test.templ ./cgi-bin/index.cgi
index.cgi の内容:
基本的に App クラスを new して app->run() としているだけである。
BEGIN ブロックのそれはライブラリへのパスを探している。
#!/usr/bin/perl -w
use strict;
my $LIB_DIR;
BEGIN {
if ($0 =~ m!(.*[/¥¥])!) {
$LIB_DIR = $1;
} else {
$LIB_DIR = './';
}
unshift @INC, $LIB_DIR . 'lib';
}
use App;
my $app = App->new();
$app->run();
1;
App.pm の内容。
#!/usr/bin/perl -w
package App;
use strict;
use base 'CGI::Application';
sub setup {
my $self = shift;
$self->mode_param('rm');
$self->start_mode('start');
$self->run_modes(
'start' => ¥&start,
'end' => ¥&end
);
$self->header_props(-type=>'text/html', -charset=>'utf-8');
}
sub teardown {
my $self = shift;
# Post-response shutdown functions
# ここにはデータベースの切断を書くとよい。
}
sub start {
my $self = shift;
my $template = $self->load_tmpl('test.tmpl', die_on_bad_params => 0,
path => ['......./cgi-bin/templates'],
# cache => 1,
# double_cache => 1,
# file_cache => 1,
# file_cache_dir => '/tmp',
# double_file_cache => 1
);
return &template($template);
}
sub end {
}
sub template {
my $template = shift;
# the fruit data - the keys are the fruit names and the values are
# pairs of color and shape contained in anonymous arrays
my %fruit_data = (
Apple => ['Red, Green or Yellow', 'Round' ],
Orange => ['Orange' , 'Round' ],
Pear => ['Green or Red' , 'Pear-Shaped'],
Banana => ['Yellow' , 'Curved' ],
);
my @loop; # the loop data will be put in here
# fill in the loop, sorted by fruit name
foreach my $name (sort keys %fruit_data) {
# get the color and shape from the data hash
my ($color, $shape) = @{$fruit_data{$name}};
# make a new row for this fruit - the keys are <TMPL_VAR> names
# and the values are the values to fill in the template.
my %row = (
name => $name,
color => $color,
shape => $shape
);
# put this row into the loop by reference
push(@loop, \%row);
}
# call param to fill in the loop with the loop data by reference.
$template->param(fruit_loop => \@loop);
# print the template
return $template->output;
}
1;
test.tmpl の内容:
<HTML>
<HEAD>
<TITLE>Fruity Data</TITLE>
</HEAD>
<BODY>
<H1>Fruity Data</H1>
<TABLE BORDER=1>
<TR>
<TD><B>Fruit Name</B></TD>
<TD><B>Color</B></TD>
<TD><B>Shape</B></TD>
</TR>
<TMPL_LOOP NAME="fruit_loop">
<TR>
<TD><TMPL_VAR NAME="name"></TD>
<TD><TMPL_VAR NAME="color"></TD>
<TD><TMPL_VAR NAME="shape"></TD>
</TR>
</TMPL_LOOP>
</TABLE>
</BODY>
</HTML>