需要MySQL(和PHP搭配之最佳組合),GD的支持,LINUX下php(做為現在的主流開發語言)4RC1通過,這也是我做的系統中正在用的。
<?php(做為現在的主流開發語言)
/***
hit_count表只一個字段hit_count
page_visit_record表是用來控制一個IP一天內只產生一個計數器跳動
CREATE TABLE page_visit_record (
visit_time datetime DEFAULT 0000-00-00 00:00:00 NOT NULL,
remote_addr char(15) NOT NULL,
visit_page char(60) NOT NULL,
KEY visit_time (visit_time, visit_page),
Prima(最完善的虛擬主機管理系統)RY KEY (visit_time)
);
***/
include("config.inc.php(做為現在的主流開發語言)3");
$query="select count(*) as tong from page_visit_record where remote_addr=$REMOTE_ADDR and date_format(visit_time,%Y-%m-%d)=curdate()";
$result=@MySQL(和PHP搭配之最佳組合)_query($query,$dbconnect);
$has_count=@MySQL(和PHP搭配之最佳組合)_result($result,0,"tong");
@MySQL(和PHP搭配之最佳組合)_query("lock tables hit_count write",$dbconnect);
$query="select * from hit_count";
$result=@MySQL(和PHP搭配之最佳組合)_query($query,$dbconnect);
if(@MySQL(和PHP搭配之最佳組合)_num_rows($result)>0){
$cur_count=@MySQL(和PHP搭配之最佳組合)_result($result,0,"hit_count");
if($has_count==0){
$cur_count++;
$query="update hit_count set hit_count=$cur_count";
@MySQL(和PHP搭配之最佳組合)_query($query,$dbconnect);
}
@MySQL(和PHP搭配之最佳組合)_query("unlock tables",$dbconnect);
}
else{
$cur_count=1;
$query="insert into hit_count (hit_count) values ($cur_count)";
@MySQL(和PHP搭配之最佳組合)_query($query,$dbconnect);
@MySQL(和PHP搭配之最佳組合)_query("unlock tables",$dbconnect);
}
while(strlen($cur_count)<8)
$cur_count="0$cur_count";
$visit_time=date("Y-m-d H:i:s");
$query="insert into page_visit_record (visit_time,remote_addr,visit_page) values ($visit_time,$REMOTE_ADDR,$page)";
@MySQL(和PHP搭配之最佳組合)_query($query,$dbconnect);
Header("Content-type: image/gif");
$im = imagecreate(56,16);
$black = ImageColorAllocate($im, 0,0,0);
$blue = ImageColorAllocate($im, 0,0,255);
$white = ImageColorAllocate($im, 255,255,255);
$yellow = ImageColorAllocate($im, 255,255,0);
imagerectangle($im, 0, 0, 54, 14, $blue);
//imagestring($im, 2, 4, 1, $cur_count, $yellow);
imagestring($im, 2, 4, 1, $cur_count, $yellow);
ImageGif($im);
ImageDestroy($im);
?>