|
作者: Aoming [aoming] 版主 | 登录 |
=============================== 一种图形显示式计数器CGI程序范例 =============================== <table border="1" bgcolor="#F5DE38" width="81"> <tr> <td width="75"><img src="http://gzcatv.huyt.net/cgi-bin/counter.cgi?position=5" width="15" height="17"><img src="http://gzcatv.huyt.net/cgi-bin/counter.cgi?position=4" width="15" height="17"><img src="http://gzcatv.huyt.net/cgi-bin/counter.cgi?position=3" width="15" height="17"><img src="http://gzcatv.huyt.net/cgi-bin/counter.cgi?position=2" width="15" height="17"><img src="http://gzcatv.huyt.net/cgi-bin/counter.cgi?position=1" width="15" height="17"></td> </tr> </table> 上面一段代码是用作调用此程序的HTML代码。在要显示计数的地方放上此段代码即可。 ########################################################### #!/usr/bin/perl $counterfile = "counter/counter.txt"; #counter.txt(计数器的数据库文件)的相对路径 $imagefile{'0'}="counter/0.gif"; # 0.gif(数字图片文件)的相对路径 $imagefile{'1'}="counter/1.gif"; $imagefile{'2'}="counter/2.gif"; $imagefile{'3'}="counter/3.gif"; $imagefile{'4'}="counter/4.gif"; $imagefile{'5'}="counter/5.gif"; $imagefile{'6'}="counter/6.gif"; $imagefile{'7'}="counter/7.gif"; $imagefile{'8'}="counter/8.gif"; $imagefile{'9'}="counter/9.gif"; ###################### $|=1; @querys = split(/&/, $ENV{'QUERY_STRING'}); foreach $query (@querys) { ($name, $value) = split(/=/, $query); $FORM{$name} = $value;} $position="$FORM{'position'}"; #上面程序段为接收浏览器送来的数据处理段 ###################### open(NUMBER,"$counterfile");#用只读方式打开记录库文件 $number=<NUMBER>;#将库文件内的数据赋给变量$number close(NUMBER);#关闭数据库 $number++;#记录数加一 if ($position==1) {#如果$position(浏览器端送来的数据)等于一,则将新数据写如数据库 open(NUMBER,">$counterfile"); print NUMBER "$number"; close(NUMBER);} if (($position>0) && ($position<=length($number))) {#如果$position大于0并且小于$number的字段位数(length($number)是截取$number的字段位数的语句) $positionnumber=substr($number,(length($number)-$position),1);#截取从$number的右边开始的第length($number)-$position)}后的一个字符。 else {#否则$positionnumber=0 $positionnumber="0";} if ($imagefile{$positionnumber}) {#如果$imagefile{$positionnumber}已定义 $imagereturn=$imagefile{$positionnumber};}#则有$imagereturn=$imagefile{$positionnumber} else {#否则$imagereturn=$imagefile{'0'} $imagereturn=$imagefile{'0'};} print "Content-type: image/gif\n\n";设定输出格式为GIF图形格式 open(IMAGE,"<$imagereturn"); print <IMAGE>;#显示$imagereturn内容的图片文件。 close(IMAGE); exit 0;#程序结束 [此贴被 Aoming(aoming) 在 11月10日21时34分 编辑过] |
地主 发表时间: 11/10 21:17 |
回复: Aoming [aoming] 版主 | 登录 |
====================== Perl连接access数据库 ====================== 前题是必须安装好activeperl,以及MS Access 一. 安装Win32-ODBC模块 步骤1: 从TOOLS栏目中下载Win32-ODBC.zip,下载完后用winzip解开到一个temp目录,共有三个文件: Readme Win32-ODBC.ppd Win32-ODBC.tar.gz 步骤2: 在DOS窗口下,temp目录中运行下面的DOS命令: ppm install Win32-ODBC.ppd 二. 准备测试用数据库(ACCESS) 步骤1: 启动MS ACCESS,建立一个新空数据库,命名为odbctest.mdb,保存在某一目录中(记住路径)。 步骤2: 然后新建一个表,建立三个字段: 字段名称 数据类型 Name 字符,长度50 Email 字符,长度50 Age 数字,长整型 将这个表保存为address(注意这个例子中,没有用自动增加的ID).输入若干记录: Nighthawk nighthawk@163.net 20 1234567 John jt@163.net 24 0284393293 kit kit@21cn.com 18 3948932 保存后,关闭数据库文件。 步骤3: 打开控制面板中的 ODBC数据源(32位),在用户DSN栏中,找到用户数据源列表,选中名称为“MS Access 97 Database”的一行,然后按“配置”键。 在Database框中按"Select..",选择步骤1.2中建立的数据库文件odbctest.mdb,按OK即可。ODBC设置中的其它项目全部采用缺省设置,然后就是OK,确定,关闭对话窗口。 三. 这时候,数据库已经可以用了,我们来测试一下: #!/usr/bin/perl use Win32::ODBC; $DSN = "MS Access 97 Database"; $DBase = "access.mdb"; #连接数据库 if (!($db = new Win32::ODBC($DSN))){ print "连接数据库失败.n"; exit(); } else{ print "连接数据库成功 (连接号:", $db->Connection(), ")nn"; } #数据库中的表 print "数据库中的表:"; @tables = $db->TableList; print @tables; print "n"; #选择数据表 if (! $db->Sql("SELECT * FROM [address] WHERE age>=20") ){ @FieldNames = $db->FieldNames(); $Cols = $#FieldNames + 1; #表中字段数 print "表address字段数:$Colsn"; #字段列表 for ($i = 0; $i < $Cols; $i++){ print "$FieldNames[$i]t"; } print "n"; #列出年龄大于20的记录 while($db->FetchRow()) { @values = $db->Data(); print @values; print "n"; } } ##### sql ######### #添加记录 $sqlinsert = "INSERT INTO address VALUES ('Euler', 'euler@21cn.com', 28, '021-345689')"; #更新记录 $sqlupdate = "UPDATE address SET age = age+10 "; #删除记录 $sqldelete = "DELETE FROM address WHERE name='jimtyan'"; $rc = $db->Sql($sqlinsert); die qq(SQL 失败 "$sqlinsert": ), $db->Error(), qq(n) if $rc; $rc = $db->Sql($sqlupdate); die qq(SQL 失败 "$sqlupdate": ), $db->Error(), qq(n) if $rc; $rc = $db->Sql($sqldelete); die qq(SQL 失败 "$sqldelete": ), $db->Error(), qq(n) if $rc; #关闭链接 +++++++++++++++++++++++++++++++++++++++++ ======================== 用perl连接mysql数据库 ======================== 一. 安装DBI模块 步骤1: 从TOOLS栏目中下载DBI.zip,下载完后用winzip解开到一个temp目录,共有三个文件: Readme DBI.ppd DBI.tar.gz 步骤2: 在DOS窗口下,temp目录中运行下面的DOS命令: ppm install DBI.ppd 如果提示无效命令,可在perl/bin目录下运行 二. 安装DBD-Mysql模块 从软件下载中下载DBD-Mysql.zip,安装方法同一. 三. 准备数据库 启动mysql,首先创建一个数据库mydata,然后创建一个表address mysql> create database mydata; Query OK, 1 row affected (0.00 sec) mysql> use mydata; Database changed mysql> create table address ( -> id int(5) not null, -> name varchar(40) not null, -> email varchar(50) not null, -> telephone int(12) null); Query OK, 0 rows affected (0.05 sec) 输入些数据: mysql> insert into address values ( -> 1,’Nighthawk’,’nighthawk@163.net’,92384092); Query OK, 1 row affected (0.00 sec) 四. 下面用perl程序来插入若干记录并做查询. use DBI; #连接数据库mydata my $dbh = DBI->connect(’DBI:mysql:mydata’) or die "无法连接数据库: " . DBI->errstr; print "插入若干记录n"; my $sth = $dbh->prepare(q{ INSERT INTO address (id, name,email,telephone) VALUES (?, ?, ?, ?) }) }); print "输入记录,回车结束:"; while ($inputdata =<>) { chop $inputdata; last unless($inputdata); my ($id, $name,$email, $tel) = split( /,/, $inputdata); $sth->execute($id, $name, $email,$tel) } # $dbh->commit; print "下面根据输入的名字打印出EMAIL地址和电话n"; my $sth = $dbh->prepare(’SELECT * FROM address WHERE name=?’) or die $dbh->errstr; print "请输入姓名,回车结束:"; while ($inputname =<>) { my @data; chomp $inputname; last unless($inputname); $sth->execute($inputname) or die "错误: " . $sth->errstr; while (@data = $sth->fetchrow_array()) { print "Email:$data[2]t Telephone:$data[3]n"; } } #断开连接 $dbh->disconnect; |
B1层 发表时间: 11/10 21:21 |
|
20CN网络安全小组版权所有
Copyright © 2000-2010 20CN Security Group. All Rights Reserved.
论坛程序编写:NetDemon
粤ICP备05087286号