----------------------------------------------------------
記數器可完成訪問 web 頁的總次數,但卻不能得知一個時段中訪問量的動態記載,下面 " /> a级黄色片网站,国产午夜在线播放,日本伦理一区二区

四虎精品视频-四虎精品成人免费网站-四虎黄色网-四虎国产视频-国产免费91-国产蜜臀97一区二区三区

寫一個用戶在線顯示的程序

在開始這篇文章時,作者假設讀者已能夠寫出一個用戶的登入認證程序.
----------------------------------------------------------
記數器可完成訪問 web 頁的總次數,但卻不能得知一個時段中訪問量的動態記載,下面就來介紹如何寫一個各個時段動態顯示訪問量的方法.

要記載訪問量,首先就要在 mysql 內建立一個數據庫,姑且給這個數據庫取名為 line,同時建立一個名為 line 的數據表,表內的字段分別為"用戶名(name varchar(20)),時間(time datetime)".當然讀者也可根據需要增加數據表的字段.

建立好數據庫后,就可以開始設計程序了,現在先理清一下思路,要想顯示訪問量,當然數據庫就必須要有記錄,我已假設讀者有能力寫一個用戶登入程序了,所以向數據庫添加紀錄可在登入程序假設為 login.php 里添加:

先給現在時間付值:$time=date('Y-m-d H:i:s');
mysql_select_db(line);
mysql_query("insert into line (name,time) values('$name','$time')");

好了,現在每一位登入的用戶在數據庫里都有了一個記錄,下面就來完成用戶在線顯示的程序 line.php:

<?
mysql_connect("local","","");
mysql_select_db(line);
$result=mysql_query("select * from line");
$num=mysql_numrows($result);
if (!empty($num)) {
echo "<table><tr><td>";
echo "現在在線人數為:$num";
echo "</td></tr>";
for($i=0;$i<$num;$i++){
$name=mysql_result($result,$i,"name");
echo "<tr><td>用戶:$name</td></tr>";
}
}
?>

上面這段程序已能顯示所有在線的用戶人數及各用戶名,當然這個程序還很不完善.如果其中一個用戶登出離開后,數據庫就不應該有此用戶的記錄所以,還得在登出程序假設為 logout.php 內加上刪除功能:

mysql_select_db(line);
mysql_query("delete from line where name='$name'");

這時一個基本的用戶在線功能已經完成,接下來繼續在 line.php 內增加代碼使功能更加完善,首先我們得規定用戶在多長時間沒繼續瀏覽 line.php 時就認為該用戶已經離開,這里給定一個時間限制為 5 分鐘,也就是說程序將顯示從現在開始的前 5 分鐘的用戶情況,所以必須 line.php 內設置一個現在時間告知程序從這個時間開始執行,然后實現程序執行時把數據庫內記錄的時間減去現在時間大于 5 分鐘的所有記錄刪除,這樣任何用戶在執行 line.php 時,都能看到 5 分鐘內的所有在線的用戶,完成這個功能需要以下這個數據庫語句:

delete from line where time<date_sub('$time',interval 5
minute)

但是其中還有一個問題就是如果有個用戶一直在不停地執行 line.php 超過 5 分鐘以上時,程序必須得分辨出該用戶并一直顯示該用戶,在這就得利用 cookie 來實現更新數據庫的時間記錄了,因為是登入認證的,所以會有個 cookie 來記住用戶的資料的,假設這個記錄用戶姓名的 cookie 變量為 $cookiename (具體的變量視 cookie 的設置而定),剩下的就很好辦了,利用這個 cookie 變量完成數據庫的修改:

update line set time='$time' where name='$cookiename'

下面來完善 line.php:

<?
//設置現在的時間
$time=date('Y-m-d H:i:s');
mysql_connect("local","","");
mysql_select_db(line);

//更新用戶的記錄
mysql_query("update line set time='$time' where name='$cookiename'");

//刪除超過 5 分鐘的用戶記錄
mysql_query("delete from line where time<date_sub('$time',interval 5 minute)");

$result=mysql_query("select * from line");
$num=mysql_numrows($result);
if (!empty($num)) {
echo "<table><tr><td>";
echo "現在在線人數為:$num";
echo "</td></tr>";
for($i=0;$i<$num;$i++){
$name=mysql_result($result,$i,"name");
echo "<tr><td>用戶:$name</td></tr>";
}
}
?>

好用戶在線顯示功能完成.

php技術寫一個用戶在線顯示的程序,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 大国崛起思维导图| 太卷了正确答案| 烽火流金电视剧免费观看完整版| 项目负责人任命书| 美女抽烟的视频| 大雄的日本诞生| 尹馨演过的三部电影| 黄子华个人资料简介| 老男人电影完整版高清在线观看| 金珉奎怎么读| 山本裕典| 我的幸福婚约电影| 重庆新闻频道| 陈澎| 忏悔三昧念3遍| 特种部队全面反击| 男人不可以穷演员表| 发现一个神奇的定胆方法| 电影吻隐者在线观看免费完整版| 吸油记游戏破解版无限金币| 生活片爱情电影大全| 第一财经公司与行业回放| 我的一级兄弟 电影| 杨梅花的图片| 李采潭全部作品| 离别的车站简谱| sandrarusso精品艳妇| 卢靖姗老公是谁| 风雨上海滩电视剧30集在线观看| 爱情三选一| 青草在线视频| 女人的战争剧情介绍| 艺术影院| 最美表演| 念念相忘电影免费观看| 熊竹英| 林景云李海海| 鬼谷子电视剧| 周琳皓| 爱情公寓海报| 大红枣儿甜又香简谱|