首頁 >後端開發 >php教程 >新手上路駕駛技巧 PHP新手上路(七)

新手上路駕駛技巧 PHP新手上路(七)

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB原創
2016-07-29 08:34:551036瀏覽

建立一個簡單互動的網站(三)
6. 密碼驗證
  也許你想在自己的網站放上你的照片集,而且只想給自己知心的朋友看,這時你需要一個密碼驗證的程序。
6.1 基於HTTP驗證
  如何用PHP來實現密碼驗證的功能呢?我們可以使用簡短的PHP程式碼,使用函數header()發送HTTP標頭強制驗證,客戶端瀏覽器則會彈出供輸入使用者名稱和密碼的對話框。在PHP中,客戶端使用者輸入的訊息傳送到服務端之後自動儲存在$PHP_AUTH_USER, $PHP_AUTH_PW, 以及 $PHP_AUTH_TYPE這三個全域變數中。利用這些變量,我們就可以根據實現保存在資料檔案或資料庫中的使用者帳號資訊驗證使用者身分。
  不過在這裡需要提醒用戶注意的一點是:只有在Apache模組方式運行的時候,PHP腳本才能使用$PHP_AUTH_USER, $PHP_AUTH_PW, 以及 $PHP_AUTH_TYPE這三個變數。如果使用者使用的是CGI模式的PHP則無法實現基於HTTP的驗證功能。  
6.2 下面,我們就來詳細介紹如何使用PHP對使用者身分進行驗證。
  在下例中,我們是使用$PHP_AUTH_USER和$PHP_AUTH_PW這兩個變數來驗證進入者是否合法並允許進入。在本例中被允許登入的使用者名稱和密碼對分別為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_AUER/$is_AUTH_MAUER/1D invalTH_ .";
exit;
}  
else  
{
echo "Welcome tnc!";
}
?>
事實上 『中可能如上面使用程式碼段明顯的使用者名稱/密碼對,而是利用資料庫或加密的密碼檔案來存取它們。  
6.3 根據指定的驗證資訊來核實使用者身分
  首先,我們可以使用以下程式碼來確定使用者是否已經輸入了使用者名稱和密碼,並顯示使用者輸入的資訊。
if (!isset($PHP_AUTH_USER)) {
header('WWW-Authenticate: Basic realm="My Private Stuff"');
header('HTTP/1.0 4011 Unauthorized');
echo 'Authorization Required.';
exit;
}
else {
echo "

You have entered this username: $PHP_AUTH_USER

You have entered this username: $PHP_AUTH_USER

The authorization type is: $PHP_AUTH_TYPE

";
}
?>
說明:
isset()函數用於確定某個變數是否已被賦值。根據變數值是否存在,傳回true或false。
header()函數用來傳送特定的HTTP標頭。注意,使用header()函數時,請務必在任何產生實際輸出的HTML或PHP程式碼前面呼叫該函數。
  雖然上述程式碼相當簡單,沒有根據任何實際值對使用者輸入的使用者名稱和密碼進行有效驗證,但是至少我們了解如何使用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)) {
else if (isset($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 "

You're authorized!

";
}
}
?>
  在這裡,我們首先檢查用戶是否已經輸入了用戶名稱和密碼,如果沒有則彈出相應對話框要求用戶輸入身份資訊。隨後,我們透過判斷使用者輸入的資訊是否符合admin/123此指定使用者帳號來授予使用者存取權限或提示使用者再次輸入正確的資訊。這種方法適用於所有使用者都使用相同登入帳號的網站。
6.4 另一種簡易的密碼驗證
  如果你是在windows98下面編寫和運行著你的PHP腳本,或者是你在Linux下面按默認設置,將PHP安裝成一個CGI程序的話,你將無法使用上面的PHP程式來實現驗證功能。為此,無邊提供了另一個簡易的密碼驗證的方法給大家。雖然實用性不大,但是拿來學習還是挺好的。
$password = "123";  
// check password
if($pass != $password)
{
echo " 管理密碼";
echo "
";
echo "請輸入你的管理密碼:";
echo "";
echo "";
echo "";
}
else
{
echo "恭喜你,你已經通過密碼驗證了 title>"; <br>echo "<script>"; <br>echo 'window.location="http://gophp.heha.net/test/index.php3"'; <br>#密碼驗證後轉入的頁面<br>echo "</script>"; <br>} <br>?>    <br> <p> 以上就介紹了新手上路駕駛技巧 PHP新手上路(七),包括了新手上路駕駛技巧方面的內容,希望對PHP教程有興趣的朋友有所幫助。 </p> <p> </p>
陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn