5.1 安装Perl模块
安装完后,apache的perl模块就安装好了
$ sudo apt-get install libapache2-mod-perl2
5.2 配置cgi-bin目录
Perl的网页程序一般都是以CGI的模式来运行,创建cgi-bin目录,并修改虚拟主机的配置
ScriptAlias /cgi-bin/ /usr/lib/cgi-bin/
<Directory "/usr/lib/cgi-bin">
AllowOverride None
Options +ExecCGI -MultiViews +SymLinksIfOwnerMatch
Order allow,deny
Allow from all
</Directory>
5.3 Perl程序测试
创建test目录并创建测试页面
$ sudo mkdir /usr/lib/cgi-bin/test
$ sudo nano /usr/lib/cgi-bin/test/test.pl
测试页面的内容
#!/usr/bin/perl -w
print "Content-type: text/html\n\n";
print "Hello, World.";
给与执行权限
$ sudo chmod a+x /usr/lib/cgi-bin/test/test.pl
5.4 用Perl访问MySQL数据库
创建连接数据库的测试页面dbtest.pl
#!/usr/bin/perl
use DBI;
# 连接数据库
my $dbh = DBI->connect("DBI:mysql:database=mydb;host=localhost","username","passw ord", {'RaiseError' => 1});
# 查询
my $sqr = $dbh->prepare("SELECT name, mail FROM users");
$sqr->execute();
# 打印结果
while(my $ref = $sqr->fetchrow_hashref()) {
print "$ref->{'name'}, $ref->{'mail'}\n";
}
# 关闭数据库连接
$dbh->disconnect();
在命令行进行测试
$ perl /var/www/dbtest.pl
Hiweed, hiweed@test.com
Ning, ning@test.com
Guoce, guoce@test.com
复制到网站目录进行测试
$ sudo cp /var/www/dbtest.pl /usr/lib/cgi-bin/test/
浏览器报告500的错误,是因为脚本不符合CGI规范,在脚本的print语句钱加上下面一行,使符合规范
print "Content-type: text/html\n\n";
修改后的脚本如下
#!/usr/bin/perl
use DBI;
my $dbh = DBI->connect("DBI:mysql:database=mydb;host=localhost","username", "passw ord", {'RaiseError' => 1});
my $sqr = $dbh->prepare("SELECT name, mail FROM users");
$sqr->execute();
print "Content-type:text/html\n\n";
while(my $ref = $sqr->fetchrow_hashref()) {
print "$ref->{'name'}, $ref->{'mail'}\n\n";
}
$dbh->disconnect();
给与执行权限
$ sudo chmod 755 /usr/lib/cgi-bin/test/dbtest.pl
5.6 实例:用Twiki假设Wiki
5.6.1 安装Twiki
Twiki是一个用perl编辑的Wiki软件,十分灵活。
安装
$ sudo apt-get install twiki
安装完后,直接访问http://192.168.1.10/cgi-bin/twiki/就可以
5.6.2 配置Twiki
如果访问http://192.168.1.10/cgi-bin/twiki/跳转到http://localhost/cgi-bin/twiki/,则需要修改配置文件。twiki的配置文件在/etc/twiki目录下,修改/etc/twiki/apache.conf文件中设置的RedirectMatch如下
RedirectMatch /twiki/?$ http://localhost/cgi-bin/twiki/view$1
RedirectMatch /twiki(/([A-Z].*)?)?$ http://localhost/cgi-bin/twiki/view$1
/etc/twiki/LocalSite.cfg配置文件也很重要,是twiki的主要配置文件,里面包括了数据目录、网站语言、登陆认证等方面的设置
文章整理来自于《Ubuntu Server最佳方案》书籍
由于字数限制,笔记可能无法全部上传,请下载笔记