目前,Apache、PHP4、MySQL三者是Linux下構建Web網站的最佳搭檔,這三個軟件都是免費軟件。將三者結合起來,通過HTTP協議,利用PHP4和MySQL,實現Apache的用戶認證功能。
只有在PHP4以Apache的模塊方式來運行的時候才能進行用戶認證。為此,在編譯Apache時需要加入PHP4模塊一起編譯。假設PHP4作為Apache的模塊,編譯、安裝Apache到/usr/local/apache目錄,編譯、安裝MySQL到/usr/local/mysql目錄。然后進行下面的步驟:
1.在MySQL中建立一個數據庫member,在其中建立一個表users,用來存放合法用戶的用戶名和密碼。
1)用vi命令在/tmp目錄建立一個SQL腳本文件auth.sql,內容為:
drop database if exists member;
create database member;
use member;
create table users (
username char(20) not null,
password char(20) not null,
);
insert into users values("user1",password("1234"));
insert into users values("user2",password("5678"));
2)啟動MySQL客戶程序mysql,執行上述SQL腳本文件auth.sql的命令, 在表users中增加兩個用戶的記錄。
#mysql -u root -pmypwd</tmp/auth.sql
2.編寫一個PHP腳本頭文件auth.inc,程序內容為:
<?php
function authenticate() {
Header(WWW-authenticate: basic realm="會員區");
Header(HTTP/1.0 401 Unauthorized);
echo "你必須輸入正確的用戶名和口令。n";
exit;
}
function CheckUser($uname, $pwd) {
if ($uname == "" || $pwd == "") return 0;
$query = "SELECT username,password FROM users WHERE username=$uname and password=password($pwd)";
$db_id = mysql_connect(localhost, oot, mypwd);
mysql_select_db(member,$db_id);
$result = mysql_query($query, $db_id);
$num=mysql_num_rows($result);
mysql_close($db_id);
if ($num>0) {
return 1; // 有效登錄
} else {
return 0; // 無效登錄
}
}
?>
新聞熱點
疑難解答