Implementierung der grundlegenden und digest -Authentifizierung in Apache mithilfe von mod_auth_basic
und mod_auth_digest
beinhaltet die Konfiguration der virtuellen Host- oder Verzeichniskonfigurationsdateien von Apache. Beginnen wir mit der grundlegenden Authentifizierung.
Grundlegende Authentifizierung:
mod_auth_basic
aktiviert ist. Dies geschieht normalerweise durch Überbrückung der LoadModule auth_basic_module modules/mod_auth_basic.so
in Ihrer Apache -Konfigurationsdatei ( httpd.conf
oder eine relevante virtuelle Host -Konfigurationsdatei). Erstellen einer Kennwortdatei: Sie benötigen eine Kennwortdatei mit Benutzernamen und deren verschlüsselten Passwörtern. Apache liefert dafür das htpasswd
-Dienstprogramm. Verwenden Sie es, um eine neue Datei (z. .htpasswd
) zu erstellen und Benutzer hinzuzufügen:
<code class="bash">sudo htpasswd -c /path/to/.htpasswd username</code>
(Das -c
-Flag erstellt eine neue Datei; lassen Sie sie aus, um Benutzer zu einer vorhandenen Datei hinzuzufügen.) Der Befehl fordert Sie für ein Kennwort auf. Wiederholen Sie dies für jeden Benutzer. Entscheidend speichern Sie diese Datei sicher; Seine Kompromisse beeinträchtigen Ihre Authentifizierung.
Konfigurieren Sie Apache: In Ihrer Apache -Konfigurationsdatei im <directory></directory>
oder <location></location>
blockieren, um den geschützten Bereich zu definieren, fügen Sie die folgenden Anweisungen hinzu:
<code class="apache"><directory> AuthType Basic AuthName "Restricted Area" AuthUserFile /path/to/.htpasswd Require valid-user </directory></code>
Ersetzen Sie /path/to/protected/directory
und /path/to/.htpasswd
durch die tatsächlichen Pfade. AuthName
legt den auf den Benutzer angezeigten Realm -Namen fest.
Verdauungsauthentifizierung:
Die Digest -Authentifizierung ist sicherer als die grundlegende Authentifizierung, da das Senden von Kennwörtern im Klartext vermieden wird. Der Prozess ist ähnlich:
mod_auth_digest
aktiviert ist (ähnlich wie mod_auth_basic
).htpasswd
-Dienstprogramm wie zuvor. Möglicherweise möchten Sie jedoch eine separate Kennwortdatei für die Digest -Authentifizierung, um die Dinge organisiert zu halten. APache konfigurieren: Die Konfiguration ähnelt der grundlegenden Authentifizierung, aber mit AuthType
geändert:
<code class="apache"><directory> AuthType Digest AuthName "Restricted Area" AuthUserFile /path/to/.htdigest Require valid-user </directory></code>
Ersetzen Sie /path/to/.htdigest
durch den Pfad zu Ihrer Digest -Passwortdatei.
Grundlegende Authentifizierung: Überträgt Benutzernamen und Kennwörter im Klartext (Base64 codiert, aber leicht dekodiert). Dies macht es anfällig für Abhören, wenn die Verbindung nicht mit HTTPS gesichert ist. Verwenden Sie niemals die grundlegende Authentifizierung ohne HTTPS.
Verdauungsauthentifizierung: Sicherer. Es überträgt einen Hash des Passworts und verhindert, dass Abhören das tatsächliche Passwort angeben. Obwohl sie deutlich sicherer als die grundlegende Authentifizierung ist, ist sie immer noch anfällig für bestimmte Angriffe wie Wiederholungsangriffe und Mist-in-the-Middle-Angriffe, wenn sie in einem sicheren Kontext (HTTPS) nicht ordnungsgemäß implementiert werden.
Apache ermöglicht eine feinkörnige Steuerung über die Authentifizierung mithilfe <directory></directory>
und <location></location>
.
<directory></directory>
: Wendet die Authentifizierung auf ein ganzes Verzeichnis und seine Unterverzeichnisse an. Der angegebene Pfad sollte absolut sein.<location></location>
: Wendet die Authentifizierung auf bestimmte URLs an, unabhängig von ihrem Standort im Dateisystem. Dies ist nützlich, um bestimmte Skripte oder Seiten zu schützen. Beispiel: Nur /private
Verzeichnis und seine Unterverzeichnisse, aber nicht /public
:
<code class="apache"><directory> AuthType Basic AuthName "Private Area" AuthUserFile /path/to/.htpasswd Require valid-user </directory> <directory> # No authentication required here </directory></code>
Denken Sie daran, Apache nach dem Vornehmen von Konfigurationsänderungen neu zu starten ( sudo systemctl restart apache2
auf Debian/Ubuntu neu).
Benutzeranmeldeinformationen werden über das htpasswd
-Dienstprogramm verwaltet.
htpasswd -m /path/to/.htpasswd newuser
(die Option -m
verwendet einen sichereren MD5 -Hashing -Algorithmus).htpasswd /path/to/.htpasswd existinguser
. Dadurch werden Sie für das neue Passwort aufgefordert.htpasswd
-Datei gelöscht werden können. Der sicherste Ansatz besteht darin, eine neue Passwortdatei mit den gewünschten Benutzern zu erstellen und dann die alte zu ersetzen. Sie müssen sicherstellen, dass alle Apache -Prozesse vor diesem Fall gestoppt werden.Denken Sie daran, immer HTTPS bei der Implementierung der HTTP -Authentifizierung zum Schutz vor Abhören zu verwenden. Betrachten Sie robustere Authentifizierungsmethoden wie OAuth 2.0 oder OpenID Connect, um die Sicherheit in Produktionsumgebungen zu erhöhen.
Das obige ist der detaillierte Inhalt vonWie implementiere ich die HTTP -Authentifizierung (Basic auth, digest auth) in Apache mit mod_auth_basic und mod_auth_digest?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!