用PHP寫(xiě)的MySQL數(shù)據(jù)庫(kù)用戶認(rèn)證系統(tǒng)代碼
更新時(shí)間:2007年03月22日 00:00:00 作者:
這兩天受朋友的托付,要我?guī)退麑?xiě)一個(gè)使用MySQL數(shù)據(jù)庫(kù)的用戶認(rèn)證系統(tǒng)。我當(dāng)然不好推脫的,只得耗費(fèi)了一晚上的休息時(shí)間,寫(xiě)了個(gè)很簡(jiǎn)單的PHP程序。
用戶認(rèn)證的原理很簡(jiǎn)單:首先需要用戶在頁(yè)面上填入用戶名和密碼,當(dāng)然沒(méi)注冊(cè)的用戶需要先注冊(cè)。然后調(diào)用數(shù)據(jù)庫(kù)搜索是否有相應(yīng)的用戶。如果有就確認(rèn),沒(méi)有則提醒用戶先注冊(cè)。使用PHP來(lái)完成這一切很簡(jiǎn)單,但需要注意的是如果想在以后的頁(yè)面中都能確認(rèn)用戶身份,使用PHP3我只能想出使用cookie的方法。要想使用session,就只能等待PHP4正式版的發(fā)布了!
第一步是做一個(gè)登錄的頁(yè)面,這兒就不多講了。我只做了個(gè)極簡(jiǎn)單的,大家可以做得漂亮點(diǎn)。
第二步開(kāi)始登錄后的確認(rèn)程序的設(shè)計(jì)。
login.php:
mysql_connect("localhost","user","password")
/*連接數(shù)據(jù)庫(kù),用戶名和密碼自行修改*/
or die("無(wú)法連接數(shù)據(jù)庫(kù),請(qǐng)重試");
mysql_select_db("userinfo")
or die("無(wú)法選擇數(shù)據(jù)庫(kù),請(qǐng)重試");
$today=date("Y-m-d H:i:s");
$query="
select id
from usertbl
where name=$name and password=$password
/*從數(shù)據(jù)庫(kù)中搜索和登錄用戶相應(yīng)的資料*/
";
$result=mysql_query($query);
$numrows=mysql_num_rows($result);
if($numrows==0){
/*驗(yàn)證是否能找出相同資料的用戶,不能則未注冊(cè)*/
echo 非法用戶
echo 請(qǐng)注冊(cè)先
echo 重試
}
else{
$row=mysql_fetch_array($result);
$id=$row[0];
$query="
update usertbl
set lastlogin=$today
where id=$id";
$result=mysql_query($query);
SetCookie("usercookie", "歡迎你,$name");
/*這里使用了cookie,以方便之后的頁(yè)面認(rèn)證。
但我未開(kāi)發(fā)完這一塊。希望有興趣的朋友指正*/
echo 登錄成功
echo 請(qǐng)進(jìn)!
}
?>
第三步當(dāng)然是做好注冊(cè)的頁(yè)面,也不多講了。
第四步是注冊(cè)后的身份確認(rèn)和輸入數(shù)據(jù)庫(kù)。
register.php:
mysql_connect("localhost","user","password") /*請(qǐng)修改用戶名和密碼*/
or die("無(wú)法連接數(shù)據(jù)庫(kù),請(qǐng)重試");
mysql_select_db("userinfo")
or die("無(wú)法選擇數(shù)據(jù)庫(kù),請(qǐng)重試");
$query="select id from usertbl where name=$name\";
/*從數(shù)據(jù)庫(kù)中搜索相同名字的用戶資料*/
$result=mysql_query($query);
$numrows=mysql_num_rows($result);
if($numrows!=0) /*找到了當(dāng)然就是有人先注冊(cè)了相同的名字*/
{echo 已有人注冊(cè)此名,請(qǐng)重新選擇名字!;}
else
{$query="insert into usertbl values(0,$name,$password,\)";
/*找不到相同的就輸入新的用戶資料*/
mysql_query($query);
echo 注冊(cè)成功;
echo 請(qǐng)登錄!;}
?>
下一步是cookie的使用,我原打算使用cookie來(lái)使每一頁(yè)都能識(shí)別用戶身份,但由于別的頁(yè)面還沒(méi)做好,不知道需要用到哪些資料。于是就只有一個(gè)很簡(jiǎn)單的使用,這里用到了php的引用:
if(!$usercookie)
{header("非法用戶");
}
?>
welcome.php:
require("cookie.php"); /*調(diào)用cookie.php*/
?>
echo $usercookie;
?>
到這兒便完成了一個(gè)很簡(jiǎn)單的用戶認(rèn)證系統(tǒng),當(dāng)然如果你要使用它還得建好數(shù)據(jù)庫(kù)。下面是我的數(shù)據(jù)庫(kù)表的結(jié)構(gòu),庫(kù)的名字是userinfo。
create table usertbl
(
ID int auto_increment primary key,
Name varchar(30),
Password varchar(20),
Lastlogin varchar(20)
);
用戶認(rèn)證的原理很簡(jiǎn)單:首先需要用戶在頁(yè)面上填入用戶名和密碼,當(dāng)然沒(méi)注冊(cè)的用戶需要先注冊(cè)。然后調(diào)用數(shù)據(jù)庫(kù)搜索是否有相應(yīng)的用戶。如果有就確認(rèn),沒(méi)有則提醒用戶先注冊(cè)。使用PHP來(lái)完成這一切很簡(jiǎn)單,但需要注意的是如果想在以后的頁(yè)面中都能確認(rèn)用戶身份,使用PHP3我只能想出使用cookie的方法。要想使用session,就只能等待PHP4正式版的發(fā)布了!
第一步是做一個(gè)登錄的頁(yè)面,這兒就不多講了。我只做了個(gè)極簡(jiǎn)單的,大家可以做得漂亮點(diǎn)。
第二步開(kāi)始登錄后的確認(rèn)程序的設(shè)計(jì)。
login.php:
復(fù)制代碼 代碼如下:
mysql_connect("localhost","user","password")
/*連接數(shù)據(jù)庫(kù),用戶名和密碼自行修改*/
or die("無(wú)法連接數(shù)據(jù)庫(kù),請(qǐng)重試");
mysql_select_db("userinfo")
or die("無(wú)法選擇數(shù)據(jù)庫(kù),請(qǐng)重試");
$today=date("Y-m-d H:i:s");
$query="
select id
from usertbl
where name=$name and password=$password
/*從數(shù)據(jù)庫(kù)中搜索和登錄用戶相應(yīng)的資料*/
";
$result=mysql_query($query);
$numrows=mysql_num_rows($result);
if($numrows==0){
/*驗(yàn)證是否能找出相同資料的用戶,不能則未注冊(cè)*/
echo 非法用戶
echo 請(qǐng)注冊(cè)先
echo 重試
}
else{
$row=mysql_fetch_array($result);
$id=$row[0];
$query="
update usertbl
set lastlogin=$today
where id=$id";
$result=mysql_query($query);
SetCookie("usercookie", "歡迎你,$name");
/*這里使用了cookie,以方便之后的頁(yè)面認(rèn)證。
但我未開(kāi)發(fā)完這一塊。希望有興趣的朋友指正*/
echo 登錄成功
echo 請(qǐng)進(jìn)!
}
?>
第三步當(dāng)然是做好注冊(cè)的頁(yè)面,也不多講了。
第四步是注冊(cè)后的身份確認(rèn)和輸入數(shù)據(jù)庫(kù)。
register.php:
復(fù)制代碼 代碼如下:
mysql_connect("localhost","user","password") /*請(qǐng)修改用戶名和密碼*/
or die("無(wú)法連接數(shù)據(jù)庫(kù),請(qǐng)重試");
mysql_select_db("userinfo")
or die("無(wú)法選擇數(shù)據(jù)庫(kù),請(qǐng)重試");
$query="select id from usertbl where name=$name\";
/*從數(shù)據(jù)庫(kù)中搜索相同名字的用戶資料*/
$result=mysql_query($query);
$numrows=mysql_num_rows($result);
if($numrows!=0) /*找到了當(dāng)然就是有人先注冊(cè)了相同的名字*/
{echo 已有人注冊(cè)此名,請(qǐng)重新選擇名字!;}
else
{$query="insert into usertbl values(0,$name,$password,\)";
/*找不到相同的就輸入新的用戶資料*/
mysql_query($query);
echo 注冊(cè)成功;
echo 請(qǐng)登錄!;}
?>
復(fù)制代碼 代碼如下:
if(!$usercookie)
{header("非法用戶");
}
?>
welcome.php:
require("cookie.php"); /*調(diào)用cookie.php*/
?>
echo $usercookie;
?>
復(fù)制代碼 代碼如下:
create table usertbl
(
ID int auto_increment primary key,
Name varchar(30),
Password varchar(20),
Lastlogin varchar(20)
);
相關(guān)文章
laravel框架模板之公共模板、繼承、包含實(shí)現(xiàn)方法分析
這篇文章主要介紹了laravel框架模板之公共模板、繼承、包含實(shí)現(xiàn)方法,結(jié)合實(shí)例形式分析了Laravel框架中公共模板的建立、模板包含、模板繼承等相關(guān)操作技巧,需要的朋友可以參考下2019-08-08tp5(thinkPHP5)操作mongoDB數(shù)據(jù)庫(kù)的方法
這篇文章主要介紹了tp5(thinkPHP5)操作mongoDB數(shù)據(jù)庫(kù)的方法,結(jié)合實(shí)例形式簡(jiǎn)單分析了mongoDB數(shù)據(jù)庫(kù)及thinkPHP5連接、查詢MongoDB數(shù)據(jù)庫(kù)的基本操作技巧,需要的朋友可以參考下2018-01-01php中PDO方式實(shí)現(xiàn)數(shù)據(jù)庫(kù)的增刪改查
PDO是mysql數(shù)據(jù)庫(kù)操作的一個(gè)公用類了,我們不需要進(jìn)行自定類就可以直接使用pdo來(lái)操作數(shù)據(jù)庫(kù)了,但是在php默認(rèn)配置中pdo是未開(kāi)啟所以我們必須先在php.ini中開(kāi)啟它才可以使用。2015-05-05TP5框架實(shí)現(xiàn)的數(shù)據(jù)庫(kù)備份功能示例
這篇文章主要介紹了TP5框架實(shí)現(xiàn)的數(shù)據(jù)庫(kù)備份功能,結(jié)合實(shí)例形式分析了TP5數(shù)據(jù)庫(kù)備份功能相關(guān)原理及實(shí)現(xiàn)方法,需要的朋友可以參考下2020-04-04Laravel框架實(shí)現(xiàn)利用監(jiān)聽(tīng)器進(jìn)行sql語(yǔ)句記錄功能
這篇文章主要介紹了Laravel框架實(shí)現(xiàn)利用監(jiān)聽(tīng)器進(jìn)行sql語(yǔ)句記錄功能,結(jié)合實(shí)例形式分析了Laravel框架監(jiān)聽(tīng)器的創(chuàng)建、引入以及使用監(jiān)聽(tīng)器記錄sql語(yǔ)句的相關(guān)操作技巧,需要的朋友可以參考下2018-06-06寶塔 php修改了php.ini配置不生效的問(wèn)題及解決方法
最近在使用hypref,php的版本是7.4,服務(wù)器linux,用寶塔安裝完php,并裝完swoole插件后,安裝了swoole后,需要在php.ini中修改一下配置文件,本文給大家分享寶塔 php修改了php.ini配置不生效的問(wèn)題及解決方法,感興趣的朋友一起看看吧2023-09-09