6. 密碼驗證

  也許你想在自己的網(wǎng)站放上你的照片集,而且只想給自己知心的朋友看,這時你需要一個密碼驗證的程序。

6.1 基于HTTP驗證

  如何用PHP來實現(xiàn)密碼驗證的功能呢?我們可 " /> 亚洲天堂国产精品,一区二区视频在线免费观看,bbbbbbbbb毛片大片按摩

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

PHP新手上路(七)

建設(shè)一個簡單交互的網(wǎng)站(三)

6. 密碼驗證

  也許你想在自己的網(wǎng)站放上你的照片集,而且只想給自己知心的朋友看,這時你需要一個密碼驗證的程序。

6.1 基于HTTP驗證

  如何用php來實現(xiàn)密碼驗證的功能呢?我們可以使用簡短的php代碼,使用函數(shù)header()發(fā)送HTTP標(biāo)頭強制驗證,客戶端瀏覽器則彈出供輸入用戶名和密碼的對話框。在php中,客戶端用戶輸入的信息傳送到服務(wù)端之后自動保存在$php_AUTH_USER, $php_AUTH_PW, 以及 $php_AUTH_TYPE這三個全局變量中。利用這些變量,我們就可以根據(jù)實現(xiàn)保存在數(shù)據(jù)文件或數(shù)據(jù)庫中的用戶帳號信息驗證用戶身份。

  不過在這里需要提醒使用者注意的一點是:只有在Apache模塊方式運行的時候,php腳本才能使用$php_AUTH_USER, $php_AUTH_PW, 以及 $php_AUTH_TYPE這三個變量。如果用戶使用的是CGI模式的php則無法實現(xiàn)基于HTTP的驗證功能。  

6.2 下面,我們就來詳細(xì)介紹一下如何使用php對用戶身份進(jìn)行驗證。

  在下例中,我們是使用$php_AUTH_USER和$php_AUTH_PW這兩個變量來驗證進(jìn)入者是否合法并允許進(jìn)入。在本例中被允許登錄的用戶名稱和密碼對分別為tnc和nature:
<?
if(!isset($php_AUTH_USER))  
{
Header("WWW-Authenticate: Basic realm="My Realm"");
Header("HTTP/1.0 401 Unauthorized");
echo "Text to send if user hits Cancel buttonn";
exit;
}  
else  
{
if ( !($php_AUTH_USER=="tnc" && $php_AUTH_PW=="nature") )
{
// 如果是錯誤的用戶名稱/密碼對,強制再驗證
Header("WWW-Authenticate: Basic realm="My Realm"");
Header("HTTP/1.0 401 Unauthorized");
echo "ERROR : $php_AUTH_USER/$php_AUTH_PW is invalid.";
exit;
}  
else  
{
echo "Welcome tnc!";
}
?>

  事實上再實際引用中不大可能如上面使用代碼段明顯的用戶名稱/密碼對,而是利用數(shù)據(jù)庫或者加密的密碼文件存取它們。  

6.3 根據(jù)指定的驗證信息核實用戶身份

  首先,我們可以使用以下代碼確定用戶是否已經(jīng)輸入了用戶名和密碼,并顯示出用戶輸入的信息。

<?php  

if (!isset($php_AUTH_USER)) {

header('WWW-Authenticate: Basic realm="My Private Stuff"');

header('HTTP/1.0 401 Unauthorized');

echo 'Authorization Required.';

exit;

}

else {

echo "<P>You have entered this username: $php_AUTH_USER<br>

You have entered this password: $php_AUTH_PW<br>

The authorization type is: $php_AUTH_TYPE</p>";

}

?>

說明:
isset()函數(shù)用于確定某個變量是否已被賦值。根據(jù)變量值是否存在,返回true或false。
header()函數(shù)用于發(fā)送特定的HTTP標(biāo)頭。注意,使用header()函數(shù)時,一定要在任何產(chǎn)生實際輸出的HTML或php代碼前面調(diào)用該函數(shù)。

  雖然上述代碼相當(dāng)簡單,沒有根據(jù)任何實際值對用戶輸入的用戶名和密碼進(jìn)行有效驗證,但是至少我們了解了如何使用php在客戶端產(chǎn)生輸入對話框。

  下面,我們就來了解一下如何根據(jù)指定的驗證信息核實用戶身份。代碼如下:

<?php

if (!isset($php_AUTH_USER)) {

header('WWW-Authenticate: Basic realm="My Private Stuff"');

header('HTTP/1.0 401 Unauthorized');

echo 'Authorization Required.';

exit;

}

else if (isset($php_AUTH_USER)) {

if (($php_AUTH_USER != "admin") || ($php_AUTH_PW != "123")) {

header('WWW-Authenticate: Basic realm="My Private Stuff"');

header('HTTP/1.0 401 Unauthorized');

echo 'Authorization Required.';

exit;

} else {

echo "<P>You're authorized!</p>";

}

}

?>

  在這里,我們首先檢查用戶是否已經(jīng)輸入了用戶名稱和密碼,如果沒有則彈出相應(yīng)對話框要求用戶輸入身份信息。隨后,我們通過判斷用戶輸入的信息是否符合admin/123這一指定用戶帳號來授予用戶訪問權(quán)限或提示用戶再次輸入正確的信息。這種方法適用于所有用戶都使用同一登錄帳號的網(wǎng)站。  

6.4 另一種簡易的密碼驗證

  如果你是在windows98下面編寫和運行著你的php腳本,或者是你在Linux下面按默認(rèn)設(shè)置,將php安裝成一個CGI程序的話,你將無法使用上面的php程序來實現(xiàn)驗證功能。為此,無邊給大家提供了另外一種簡易的密碼驗證的方法。雖然實用性不大,但是拿來學(xué)習(xí)還是挺好的。
<?php
$password = "123";  

// check password
if($pass != $password)
{
echo "<html><head><title>管理密碼</title></head><body>";
echo "<form method="post" action=$php_SELF>";
echo "請輸入你的管理密碼:<br>";
echo "<input type="password" name="pass">";
echo "<input type="submit" value="continue">";
echo "</form></body></html>";
}
else
{
echo "<html><head><title>恭喜你,你已經(jīng)通過了密碼驗證</title></head>";
echo "<script>";
echo 'window.location="http://gophp.heha.NET/test/index.php3"';
# 通過密碼驗證后轉(zhuǎn)入的頁面
echo "</script>";

}
?>    

php技術(shù)PHP新手上路(七),轉(zhuǎn)載需保留來源!

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

主站蜘蛛池模板: 大海在呼唤| telephone翻译| 下巴有个凹陷| 挤鼻子黑头超多视频| 黑帮大佬和我的三百六十五日| 第一财经在线直播电视| 小镇姑娘高清播放| 我们的日子演员表| 生活秀| 沙鲁克汗| 都市频道节目表| 妹妹扮演的角色| 3片| 裸体摸特| 电视剧火流星演员表| 10000个常用人名| 生死千里| 野性狂欢大派对| 男人不可以穷演员表| 团结力量歌词大全图片| 欧美日韩欧美日韩| 在线看色戒| 甄嬛传演员表| 幸福年民乐合奏曲简谱| 猫电影| 护航电影| 山上的小屋 残雪原文| 色戒在线观看视频| 张达| 《摧花狂魔》电影| 杨舒惠| 林书宇| 电视剧零下三十八度手机免费观看| 军官与男孩| 伊人春色在线观看视频| 车仁表图片| 丁丁历险记电影| 电影疯狂| 护送钱斯| 美女被吃| 日韩成人av电影77777|