Heim  >  Artikel  >  Backend-Entwicklung  >  So implementieren Sie die Benutzerauthentifizierung mit PHP APACHE

So implementieren Sie die Benutzerauthentifizierung mit PHP APACHE

PHP中文网
PHP中文网Original
2016-08-08 09:34:101365Durchsuche

Auf professionellen Websites werden häufig die Kontonummern und Passwörter der Benutzer benötigt, was eine Aktion zur Identitätsbestätigung darstellt. Der frühe NCSA-httpd-Server bot diese Benutzerauthentifizierungsfunktion nicht und der Webmaster konnte nur manuell ein CGI-Programm zur Identitätsauthentifizierung erstellen.
Die meisten Webserver seit CERN httpd bieten eine Funktion zur Überprüfung der Benutzeridentität. Obwohl die Einstellungen jedes Webservers unterschiedlich sind, sind die Einstellungen ähnlich.

Im Folgenden sind die Benutzerauthentifizierungseinstellungen auf dem Apache-Server aufgeführt.

<Directory /home/MyMember> 
AuthType Basic 
AuthName MyMember 
AuthUserFile /usr/local/MyMember.txt 
Options Includes ExecCGI 
<Limit GET POST> 
require valid-user 
</Limit> 
</Directory>




Wenn der Benutzer in diesem Beispiel alle Dateien im MyMember-Verzeichnis anzeigt, einschließlich Bilddateien und anderer verschiedener Dateien, muss er bestätigen das Konto und das Passwort des Benutzers. Die Konto- und Passwortdateien des Benutzers sind in /usr/local/MyMember.txt vorhanden.

Die Kontopasswortdatei /usr/local/MyMember.txt könnte wie im folgenden Beispiel aussehen. Die Zeichenfolge vor dem Doppelpunkt ist das Benutzerkonto und die Zeichenfolge nach dem Doppelpunkt ist das irreduzibel verschlüsselte Kennwort. Die ersten beiden Zeichen des Kennworts sind Seeds (Salt In). In diesem Fall ist alles 3P. Jede Zeile repräsentiert einen Benutzer. Natürlich muss der Webmaster die Situation doppelter Konten selbst kontrollieren. Das Besondere ist die Situation, wenn Apache auf einem Win32-System gestartet wird. Das Passwort nach dem Doppelpunkt kann nicht verschlüsselt werden, da Win32 diese Verschlüsselungs-
-API nicht bereitstellt, sodass das Benutzerpasswort in klarem Code vorliegt.

john1234:3PWudBlJMiwro  
queenwan:3PFNVLNPN9W0M  
noname00:3PEsXaJx5pk7E  
wilson49:3PjoWb0EnaG22  
rootboot:3PIt0snI6.84E  
sun_moon:3PvymMeNOc.x.  
nobody38:3PbskPKwV94hw

Auf Apache Version 1.3.6 können Sie ~apache/bin/htpasswd verwenden, um ein einzelnes Konto und Passwort zu generieren, aber für kommerzielle Websites, die große Mengen an Informationen erfordern, Möglicherweise müssen Sie Ihr eigenes Programm schreiben, um damit umzugehen. Unter UNIX ist ein Aufruf von crypt() erforderlich, um die Codierung durchzuführen.



Nachdem alles eingerichtet ist, erscheint beim Herstellen einer Verbindung ein Fenster zur Passwortüberprüfung im Browser. Das Bild oben zeigt den Benutzerüberprüfungsmechanismus der MySEED-Website von SEEDNet. Nach Eingabe des Kontos und Passworts verschlüsselt der Browser diese mit BASE64 und übermittelt sie an den Server. Natürlich ist BASE64 nur eine Verschlüsselung, aber keine Verschlüsselung, daher ist die Sicherheit dieser Art der Übertragung im Internet immer noch nicht hoch. Sie kann dennoch vom Henker abgefangen und dann in BASE64 wiederhergestellt werden in der gesamten Benutzerauthentifizierung Möglicherweise kann dieses Problem in Zukunft durch die Unterstützung der Digest-Authentifizierung (Digest) und die Verwendung der MD5-Codierung gelöst werden. Danach sind für jede Seite immer noch ein Konto und ein Passwort erforderlich, der Browser sendet diese jedoch automatisch für Sie aus, sodass Sie Ihr Konto und Ihr Passwort nicht eingeben müssen. Dieser Aspekt bleibt erhalten, bis der Browser geschlossen wird, und Sie müssen ihn beim nächsten erneuten Ausführen des Browsers erneut eingeben.

Wenn die Anzahl der Benutzer gering ist, ist die Verwendung der oben genannten Methode einfach und problemlos. Wenn es jedoch Zehntausende oder sogar Hunderttausende Benutzer gibt, wird die Effizienz des gesamten Servers durch die Suche nach Kontokennwörtern beeinträchtigt, und das Lesen einer Seite kann mehrere zehn Sekunden bis Minuten dauern. In diesem Fall wäre es unklug, den vom Server bereitgestellten Mechanismus zur Passwortprüfung zu verwenden. Sie können NSAPI verwenden, um Ihre eigene Prüfmethode auf Netscape EnterPRise Server zu entwickeln, und Sie können auch ISAPI-Filter auf IIS verwenden. Es ist immer ermüdend, C/C-Programme zum Aufrufen von NSAPI/ISAPI zu schreiben. In PHP gibt es noch eine weitere Möglichkeit, die auch das Thema dieses Abschnitts ist.


Die HTTP-bezogene Funktionsbibliothek von PHP stellt die Funktion header() bereit. Viele Webserver-Client-Interaktionen können diese Funktion nutzen, um Zauber zu bewirken. Wenn Sie beispielsweise das folgende Programm am Anfang einer PHP-Seite, also in der ersten oder zweiten Zeile, hinzufügen, können Benutzer auf die Webseite des Autors weitergeleitet werden.


<?php  
header("Location: http://wilson.gs");  
exit;  
?>


Natürlich wird der HTML-Text oder das PHP-Programm nach dem oben genannten Programm niemals auf der Benutzerseite angezeigt.

Aus dem gleichen Grund verwenden wir header(), um Tricks zur Benutzerauthentifizierung durchzuführen. Sie können dem Benutzer zu Beginn von PHP eine Zeichenfolge senden, woraufhin das unten gezeigte Fenster beim Benutzer angezeigt wird.


<?php  
Header("WWW-Authenticate: Basic realm="Member"");  
Header("HTTP/1.0 401 Unauthorized");  
?>

在程式中字串 realm="Member" 中的 Member 字样出现在图中,当然若使用中文字取代,浏览器端也会出现中文字,如上面的 MySEED 图。若 Web 站台使用者还有其它语文,如英文或日文,送出中文的 realm 字串似乎就比较不合适。无论如何,这都要视站台的性质及使用者定位而决定。  

当然这还是很粗糙,因为除了送出视窗后,就没有下文了,帐号输入正确也好,输入错误也罢,都不会有任何的结果。我们需要再更进阶的程式来处理。  


在后端的使用认证上,考虑使用资料库作为储存帐号及密码的后端,在这种架构可以容纳许多的使用者,管它一万个使用者还是十万个使用者。若您的站已有数十万个使用者帐号,那么恭喜您,您的站算是世界级的大站了。MySQL 是个不错的选择,许多站台,甚至是商业化的站台都用它来做后端的资料库。当然您要架真正的商业站台,钱不是问题的话,那可以使用口碑最广的 Oracle 资料库系列。  

要在 PHP 中使用任何资料库,都要先将资料库的伺服器端及客户端设定好,之后才编译 PHP 及 Apache 系统。  

准备好 MySQL 及 PHP 之后,先在 MySQL 中加入新的资料库,本例是加入mymember,用别的名字当然也可以。MySQL 要加入资料库 (Database) 很容易,只要在MySQL 存放 Database 的地方 mkdir 就可以了。例如在 UNIX Shell 下打  

hahaha:/usr/local/mysql/data# mkdir mymember

在建立了资料库之后,尚需要建立资料表格 (Table) 方能使用。设定的表格如下,可以将它储在 /tmp/memberauth.sql 中  

CREATE TABLE MemberAuth (  
Serial mediumint(9) NOT NULL auto_increment,  
Username char(8) NOT NULL,  
PassWord char(8) NOT NULL,  
Enable char(1) DEFAULT ’0’ NOT NULL,  
PRIMARY KEY (Serial)  
);

档案 memberauth.sql  

先看看 memberauth.sql 的这些栏位。Serial 是个自动增加的整数栏位,每输入一笔资料,就会自动加一,这当然不能是空的栏位,于是就用 NOT NULL 了。第二个栏位是 Username,代表使用者的帐号,为了统一以及适应各系统起见,设定成八个字,当然这个栏位也不能是空的。Password 是第三个栏位,为使用者的密码。第四个栏位 Enable 做为帐号是否有效的旗标,设计上 0 表示无用,1 表可用,日后还可加入其它值做不同的用途。  

设计好了资料表之后,就要将资料表加入资料库了。由于常要使用 MySQL 资料库,可以到 http://www.phpwizard.net/phpMyAdmin 下载 phpMyAdmin,使用浏览器操作及管理 MySQL,轻松又方便。若使用这套 phpMyAdmin 可以在它的使用者介面上输入memberauth.sql 加入 MySQL 中。或者也可以在 UNIX Shell 下输入下式,也是有同样的效果。  

mysql mymember < /tmp/memberauth.sql

在准备好了之后,就可以输入使用者帐号及密码在 memberauth 资料表中了。当然还是使用 phpMyAdmin 方便,用 mysql 程式就要一笔笔的 INSERT 了。  

接着进入了设计函式的阶段了。  


<?php  
file://---------------------------  
// 使用者认证函式 auth.inc  
// Author: Wilson Peng  
// Copyright (C) 1999  
file://---------------------------  
$error401 = "/home/phpdocs/error/401.php";  
if ($PHP_AUTH_PW=="") {  
Header("WWW-Authenticate: Basic realm="超金卡会员"");  
Header("HTTP/1.0 401 Unauthorized");  
include($error401);  
exit;  
} else {  
$db_id = mysql_pconnect("localhost", "myid", "mypw");  
$result = mysql_db_query("mymember","select password, enable  
from MemberAuth where username=’$PHP_AUTH_USER’");  
$row = mysql_fetch_array($result);  
$MemberPasswd = $row[0];  
$MemberEnable = $row[1];  
if ($MemberEnable==0) {  
echo "您的帐号被停用了";  
exit;  
}  
if ($PHP_AUTH_PW!=$MemberPasswd) {  
Header("WWW-Authenticate: Basic realm="超金卡会员"");  
Header("HTTP/1.0 401 Unauthorized");  
include($error401);  
exit;  
}  
}  
?>

Copyright (C) 1999, Wilson Peng  

要使用这个 auth.inc,要在每个 PHP 的第一行加入  

<? require("auth.inc"); ?> 。

在加入本程式的 PHP 档案都会检查帐号密码,图片等就不会检查,比起使用 Web 伺服器功能的某目录下全都检查,PHP 显得有弹性多了。

$error401 = "/home/phpdocs/error/401.php";

这行表示在使用者按下取消,或检查失败时,要显示给使用者看的档案。 

if ($PHP_AUTH_PW=="") { 
Header("WWW-Authenticate: Basic realm="超金卡会员""); 
Header("HTTP/1.0 401 Unauthorized"); 
include($error401); 
exit; 
} else

到 else 之前,若没有传入密码,则送出输入密码的视窗。其中的 
$PHP_AUTH_USER、$PHP_AUTH_PW 是 PHP 中特殊的变数,分别代表使用者确认的帐号及密码。上面的程式也是利用这二个变数来处理使用者认证。 

$db_id = mysql_pconnect("localhost", "myid", "mypw"); 
$result = mysql_db_query("mymember","select password, enable from 
MemberAuth where username=’$PHP_AUTH_USER’"); 

$row = mysql_fetch_array($result); 
$MemberPasswd = $row[0]; 
$MemberEnable = $row[1];

若使用者有输入帐号及密码,则向资料库查询。同时查核该使用者是否仍可使用。 

if ($MemberEnable==0) { 
echo "您的帐号被停用了"; 
exit; 
}

上四行程式为帐号被停用的情形。 

if ($PHP_AUTH_PW!=$MemberPasswd) { 
Header("WWW-Authenticate: Basic realm="超金卡会员""); 
Header("HTTP/1.0 401 Unauthorized"); 
include($error401); 
exit; 
}

密码错误则再次向使用者要求输入帐号及密码。 

在实际使用时,可以视需要加入的网页再加入 auth.inc 这个档案,就不用连看张图形也要查一次密码,降低伺服器和使用者二端的资源。当然,和 MySQL 的连系上,可以使用 mysql_pconnect() 一直和 MySQL 伺服器连线。或是使用mysql_connect() 每次重新连线,用这个函式要记得早点使用 mysql_close() 将资料库关闭。下面的程式 auth1.inc 是另一版本的认证程式,就是开启连线后马上关闭,释放资源的例子。 

以上就是PHP+APACHE实现用户验证的方法的内容,更多相关内容请关注PHP中文网(www.php.cn)!


Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn