国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

基于PHP+MySQL的聊天室設計

瀏覽:2日期:2023-12-26 11:18:31

MySQL并發能力強、響應速度快,是性能優異的數據庫軟件;PHP是功能強大的服務器端腳本語言。筆者在網站開發中,采用PHP4.0+MySQL3.23.38建立了多種應用。下面,以一個簡單的聊天室設計為例,介紹PHP+MySQL在網頁開發中的應用。

1、總體設計

1. 1 構思與規劃:

聊天室的基本原理,就是把每個連上同一網頁的用戶傳送的發言數據儲存起來,然后將所有的發言數據傳給每一用戶。也就是說,用數據庫匯集每個人的發言,并將數據庫中的數據傳給每一個人就實現了聊天室的功能。

1.2 表設計

首先使用MySQL建立表chat用來儲存用戶的發言:

mysql> CREATE TABLE chat -> (chtime DATATIME,-> nick CHAR(10) NOT NULL,->words CHAR(150));

表中只設定了三個域,chtime是發言的時間,nick為發言者的昵稱,words是發言的內容,發言最多150個字符

1.3 網頁設計

一個最簡單的聊天室通常需要兩個頁框:一個頁框是用戶輸入發言的表單,另一個用來顯示大家的發言。所以代碼段通常至少需要如下幾段:

建立頁框的結構(main.php)

顯示大家發言的程序段(cdisplay.php)

傳送用戶發言的程序段(speak.php)

用戶登錄進入聊天室程序段(login.php)

2 、代碼設計

以上規劃完成后,就可以著手代碼設計了,采用php可以非常簡明實現以上的功能。

2.1 用戶登錄login.php,本段代碼是一個完全HTML網頁

<html><head><title>用戶登錄</title></head><body>請輸入您的昵稱<br><form action='main.php' method='post' target='_self'><input type='text' name='nick' cols='20'><input type='submit' value='登錄'></body></html>

用戶提交自己的昵稱后,就進入到聊天室,以下的處理交由main.php處理。

2.2 頁框主體代碼段main.php:

<?setcookie('nick',$nick) //用cookie記錄用戶昵稱,是常用的傳遞變量方法?><html><title>山西鋁廠聊天室試用版ver1.0</title><frameset rows='80%,*'><frame src='http://www.cgvv.com.cn/bcjs/ cdisplay.php' name='chatdisplay'><frame src='http://www.cgvv.com.cn/bcjs/speak.php' name='speak'></frameset></html>

2.3 顯示發言cdisplay.php

本代碼段的任務是將表chat中的數據取出,顯示在頁框中。每次刷新時,取數據庫中最近的15條發言。同時,為防止數據庫無限增大,需設計刪除陳舊數據的功能。代碼如下

<html><head><title>顯示用戶發言</title><meta http-equiv='refresh' content='5;url=cdisplay.php'></head><body><?$link_ID=mysql_connect('main','root');//鏈接Mysql服務器 服務器名為main,管理員名為rootmysql_select_db('abc'); //選擇數據庫$str='select * from chat ORDER BY chtime;' ; //查詢字符串$result=mysql_query($str, $link_ID); //送出查詢$rows=mysql_num_rows($result); //取得查詢結果的記錄筆數//取得最后15筆發言,并顯示@mysql_data_seek($resut,$rows-15); //移動記錄指針到前15筆記錄if ($rows<15) $l=$rows; else $l=15; //記錄總數小于15,則最多為該記錄數for ($i=1;$i<=$l;$i++) {list($chtime,$nick,$words)=mysql_fetch_row($result);echo $chtime; echo ' ';echo $nick; echo':' ; echo $words; echo '<BR>';}//清除庫中過時的數據@mysql_data_seek($result,$rows-20); //移動記錄指針到前20筆記錄list($limtime)=mysql_fetch_row($result);$str='DELETE FROM chat WHERE chtime<'$limtime' ;' ;$result=mysql_query($str,$link_ID); //送出查詢字符串,庫中只留前20個記錄mysql_close($link_ID);?></body></html>

2.4 送出發言到數據庫speak.php

<html><head><title>發言</title></head><body><?If ($words){ $link_ID=mysql_connect('main','root');mysql_select_db('abc'); //數據庫名為abc$time=date(y).date(m).date(d).date(h).date(i).(date(s); //取得當前時間$str='INSERT INTO chat(chtime,nick,words) values('$time','$nick','$words');' ; mysql_query($str,$link_ID); //送出發言到數據庫mysql_close($link_ID);}?>//輸入發言的表單<form action='speak.php' method='post' target=' _self'><input type='text' name='words' cols='20'><input type='submit' value='發言'></form></body></html>

完成以上工作后,一個簡單的聊天室制作就完成了。當然,設計者可以根據個人愛好做一些個性化設計,如增加一個頁框,顯示當前聊天室人員名單、增加發言表情、取得發言者IP、進一步美化頁面等等。

標簽: PHP
主站蜘蛛池模板: 99国产福利视频在线观看 | 欧美一区二区视频在线观看 | 欧美成人性做爰 | 91手机看片国产福利精品 | 亚洲精品成人a | 欧美怡红院在线观看 | 九九精品免视频国产成人 | 天天视频一区二区三区 | 一级一片免费看 | 三级在线国产 | 美女张腿男人桶免费视频 | 波野多结衣在线观看 | 99je全部都是精品视频在线 | 成人黄激情免费视频 | 国产欧美曰韩一区二区三区 | 一级视频在线免费观看 | 国产成人精品实拍在线 | 日韩激情中文字幕一区二区 | 在线免费看一级片 | 午夜男人女人爽爽爽视频 | 亚洲精品欧美精品一区二区 | 黑人巨大videos极度另类 | 日韩美女一区二区三区 | 日本黄页免费 | 中文字幕视频在线 | 亚洲影院中文字幕 | 成人免费视频播放 | 一级a毛片 | 欧美啊v在线观看 | 亚洲高清国产品国语在线观看 | 日本一本久道 | 欧美视频一区二区三区 | 免费观看情趣v视频网站 | 美女张开大腿让男人桶 | 香蕉依依精品视频在线播放 | 亚洲男人的天堂久久香蕉 | 一级做a爰片久久毛片苍井优 | 日韩欧美特级毛片 | 99久久免费看精品国产一区 | 久久久久久极精品久久久 | 伊人久久免费 |