Available Languages
Manual for Zend Framework 1.0.3
Inhaltsverzeichnis
Zend_Auth bietet eine API für das Authentifizieren und enthält konkrete Authentifizierungs-Adapter für übliche Use Case Szenarien.
Zend_Auth behandelt nur die Authentifizierung und nicht die Authorisierung. Authentifizierung ist lose definiert als das Ermitteln ob eine Entität aktuell das ist was Sie vorgibt zu sein (z.B. Identifizierung), basierend auf einem Set von Zeugnissen. Authorisierung, der Prozess des Entscheidens ob es einer Entität erlaubt wird auf andere Entitäten Zugriff zu erhalten, oder um auf diesen Operationen durchzuführen, ist ausserhalb der Möglichkeit von Zend_Auth. Für weitere Informationen über Authorisierung und Zugriffskontrolle mit dem Zend Framework, sollte Zend_Acl angeschaut werden.
![]() |
Anmerkung |
|---|---|
Die |
Ein Zend_Auth Adapter wird verwendet um sich gegenüber einem speziellen Typ von Authentifizierungs Services zu authentifizieren, wie LDAP, RDBMS, oder Datei-basierenden Speichern. Verschiedene Adapter besitzen leicht unterschiedliche Optionen und Verhaltensweisen, aber einige grundlegende Dinge sind für Authentifizierungs Adapter üblich. Zum Beispiel das die Authentifizierung Zeugnisse akzeptiert werden (enthält auch vorgegebene Identitäten), das Abfragen am Authentifizierungsservice durchgeführt werden, und das Ergebnisse zurückgegeben werden, sind für Zend_Auth Adapter üblich.
Jede Zend_Auth Adapter Klasse implementiert Zend_Auth_Adapter_Interface. Dieses
Interface definiert eine Methode, authenticate(), die eine Adapter Klasse implementieren
muß um eine Authentifizierungsanfrage auszuführen. Jede Adapter Klasse muß vorher vorbereitet sein
bevor authenticate() aufgerufen wird. Diese Vorbereitung des Adapters enthält das
Setzen der Zeugnisse (z.B. Benutzername und Passwort) und die Definition von Werten für
Adapter spezifische Konfigurationoptionen, wie Datenbank Verbindungsdaten für einen Datenbank
Tabellen Adapter.
Das folgende ist ein Beispiel eines Authentifierungs-Adapters der einen Benutzernamen und ein Passwort für die Authentifizierung benötigt. Andere Details, wie zum Beispiel der Authentifizierungs-Service abgefragt wird, werden der Kürze halber ausgelassen:
<?php
require_once 'Zend/Auth/Adapter/Interface.php';
class MyAuthAdapter implements Zend_Auth_Adapter_Interface
{
/**
* Setzt Benutzername und Passwort für die Authentifizierung
*
* @return void
*/
public function __construct($username, $password)
{
// ...
}
/**
* Führt einen Authentifizierungs-Versuch durch
*
* @throws Zend_Auth_Adapter_Exception Wenn die Authentifizierung nicht durchgeführt wurde
* @return Zend_Auth_Result
*/
public function authenticate()
{
// ...
}
}
Wie im Docblock angegeben, muß authenticate() eine Instanz von
Zend_Auth_Result (oder einer von Zend_Auth_Result abgeleiteten Klassen)
zurückgeben. Wenn aus bestimmten Gründen eine Durchführung einer Authentifizierungs-Anfrage
nicht möglich ist, sollte authenticate() eine Ausnahme werfen die von
Zend_Auth_Adapter_Exception abgeleitet ist.
Zend_Auth Adapter geben eine Instanz von Zend_Auth_Result mit Hilfe von
authenticate() zurück um die Ergebnisse des Authentifizierungs-Versuches darzustellen.
Adapter veröffentlichen das Zend_Auth_Result Objekt bei der Erstellung, so das die
folgenden drei Methoden ein grundsätzliches Set von Benutzerbezogenen Operationen bieten die
für die Ergebnisse von Zend_Auth Adapter üblich sind:
isValid()- Gibt true zurück wenn und nur wenn das Ergebnis einen erfolgreichen Authentifizierungs-Versuch repräsentiertgetCode()- Gibt einen konstantenZend_Auth_ResultIdentifizierer damit der Typ des Authentifizierungs-Fehlers, oder des Erfolgs der stattgefunden hat, ermittelt werden kann. Das kann in Situationen verwendet werden in denen der Entwickler die verschiedenen Ergebnistypen der Authentifizierung unterschiedlich behandeln will. Das erlaubt es dem Entwickler zum Beispiel detailierte Statistiken über die Authentifizierungs-Ergebnisse zu erhalten. Eine andere Verwendung dieses Features ist es spezielle, benutzerdefinierte Nachrichten anzubieten, um Benutzern eine bessere Usability zu ermöglichen, einfach dadurch das Entwickler dazu aufgerufen sind die Risiken solche defailierte Informationen Benutzern anzubieten, statt einer generellen Nachricht eines Authentifizierungs-Fehlers. Für weitere Informationen siehe die Notiz anbei.getIdentity()- Gibt die Identität des Authentifizierungs-Versuchs zurückgetMessages()- Gibt ein Array von Nachrichten zurück nach einem fehlgeschlagenen Authentifizierungs-Versuch
Ein Entwickler kann wünschen basierend auf dem Typ des Authentifizierungs-Ergebnisses zu verzweigen um spezialisiertere Operationen durchzuführen. Einige Operationen die für Entwickler nützlich sein können sind zum Beispiel das Sperren von Konten nachdem zu oft ein falsches Passwort angegeben wurde, das markieren von IP Adressen nachdem zuviele nicht existierende Identitäten angegeben wurden und das anbieten von speziellen, benutzerdefinierten Nachrichten für Authentifizierungs-Ergebnisse an den Benutzer. Die folgenden Ergebniscodes sind vorhanden:
Zend_Auth_Result::SUCCESS
Zend_Auth_Result::FAILURE
Zend_Auth_Result::FAILURE_IDENTITY_NOT_FOUND
Zend_Auth_Result::FAILURE_IDENTITY_AMBIGUOUS
Zend_Auth_Result::FAILURE_CREDENTIAL_INVALID
Zend_Auth_Result::FAILURE_UNCATEGORIZED
Das folgende Beispiel zeigt wie ein Entwickler anhand des Ergebniscodes verzweigen könnte:
<?php
// Innerhalb von AuthController / loginAction
$result = $this->_auth->authenticate($adapter);
switch ($result->getCode()) {
case Zend_Auth_Result::FAILURE_IDENTITY_NOT_FOUND:
/** Was wegen nicht existierender Identität machen **/
break;
case Zend_Auth_Result::FAILURE_CREDENTIAL_INVALID:
/** Was wegen ungültigen Zeugnissen machen **/
break;
case Zend_Auth_Result::SUCCESS:
/** Was wegen erfolgreicher Authentifizierung machen **/
break;
default:
/** Was wegen anderen Fehlern machen **/
break;
}
Eine Anfrage zu authentifizieren die Authentifizierungs Zeugnisse enthält ist per se nützlich, aber auch wichtig um die Authentifizierungs Identität bearbeiten zu können ohne das immer die Authentifizierungs Zeugnisse mit jeder Anfrage vorhanden sein müssen.
Trotzdem ist HTTP ein statusloses Protokoll, und Techniken wie Cookies und Sessions wurden entwickelt um Stati über mehrere Anfragen hinweg in Server-seitigen Web Anwendungen zu erhalten.
Standardmäßig bietet Zend_Auth dauerhafte Speicherung der Identität eines
erfolgreichen Authentifizierungs Versuches durch Verwendung der PHP Session. Bei einem
erfolgreichen Authentifizierungs Versuch speichert Zend_Auth::authenticate()
die Identität des Authentifizierungs Ergebnisses im persistenten Speicher. Solange die
Konfiguration nicht verändert wird, verwendet Zend_Auth eine Speicherklasse
die Zend_Auth_Storage_Session heißt und die im Gegenzug
Zend_Session verwendet. Eine eigene Klasse kann stattdessen
verwendet werden, indem ein Objekt an Zend_Auth::setStorage() übergeben wird
welches Zend_Auth_Storage_Interface implementiert.
![]() |
Anmerkung |
|---|---|
Wenn das automatische persistente Speichern der Identität für einen bestimmten Anwendungsfall
nicht anwendbar ist, können Entwickler trotzdem die |
Beispiel 3.1. Den Namensraum der Session ändern
Zend_Auth_Storage_Session verwendet einen Session Namensraum von
'Zend_Auth'. Diese Namensraum kann überschrieben werden indem ein anderer
Wert an den Konstruktor von Zend_Auth_Storage_Session übergeben wird, und dieser
Wert wird intern an den Konstruktor von Zend_Session_Namespace weitergereicht.
Das sollte vor einem Versuch einer Authentifizierung stattfinden da
Zend_Auth::authenticate() die automatische Speicherung der Identität durchführt.
<?php
// Eine Referenz zur Singleton Instanz von Zend_Auth speichern
require_once 'Zend/Auth.php';
$auth = Zend_Auth::getInstance();
// 'someNamespace' statt 'Zend_Auth' verwenden
require_once 'Zend/Auth/Storage/Session.php';
$auth->setStorage(new Zend_Auth_Storage_Session('someNamespace'));
/**
* @todo Den Auth Adapter $authAdapter erstellen
*/
// Authentifizieren, das Ergebnis speichern, und die Identität bei Erfolg persistent machen
$result = $auth->authenticate($authAdapter);
Zeitweise wollen Entwickler ein anderes Verhalten der Persistenz für Identitäten erhalten als
es von Zend_Auth_Storage_Session angeboten wird. Für solche Fälle können
Entwickler einfach Zend_Auth_Storage_Interface implementieren und eine
Instanz der Klasse an Zend_Auth::setStorage() übergeben.
Beispiel 3.2. Eine eigene Speicher Klasse verwenden
Um eine andere Speicherklasse für die Persistenz von Identitäten zu verwenden als sie
durch Zend_Auth_Storage_Session angeboten wird, können Entwickler
Zend_Auth_Storage_Interface implementieren:
<?php
require_once 'Zend/Auth/Storage/Interface.php';
class MyStorage implements Zend_Auth_Storage_Interface
{
/**
* Gibt true zurück wenn und nur wenn der Speicher leer ist
*
* @throws Zend_Auth_Storage_Exception Wenn es unmöglich ist festzustellen ob der Speicher leer ist
* @return boolean
*/
public function isEmpty()
{
/**
* @todo Implementierung
*/
}
/**
* Gibt den Inhalt des Speichers zurück
*
* Das Verhalten ist undefiniert wenn der Speicher leer ist.
*
* @throws Zend_Auth_Storage_Exception Wenn das Lesen von Lesen vom Speicher unmöglich ist
* @return mixed
*/
public function read()
{
/**
* @todo Implementierung
*/
}
/**
* Schreibt $contents in den Speicher
*
* @param mixed $contents
* @throws Zend_Auth_Storage_Exception Wenn das Schreiben von $contents in den Speicher unmöglich ist
* @return void
*/
public function write($contents)
{
/**
* @todo Implementierung
*/
}
/**
* Löscht die Intalte vom Speicher
*
* @throws Zend_Auth_Storage_Exception Wenn das Löschen der Inhalte vom Speicher unmöglich ist
* @return void
*/
public function clear()
{
/**
* @todo Implementierung
*/
}
}
Um diese selbstgeschriebene Speicherklasse zu verwenden wird
Zend_Auth::setStorage() aufgerufen bevor eine Authentifizierungsanfrage
stattfindet:
<?php
// Zend_Auth anweisen das die selbstdefinierte Speicherklasse verwendet wird
Zend_Auth::getInstance()->setStorage(new MyStorage());
/**
* @todo Den Auth Adapter $authAdapter erstellen
*/
// Authentifizieren, das Ergebnis speichern, und die Identität bei Erfolg
$result = Zend_Auth::getInstance()->authenticate($authAdapter);
Es gibt zwei vorhandene Wege um Zend_Auth Adapter zu verwenden:
Indirekt durch
Zend_Auth::authenticate()Direkt durch die
authenticate()Methode des Adapters
Das folgende Beispiel zeigt wie ein Zend_Auth Adapter indirekt verwendet werden kann, durch die
verwendung der Zend_Auth Klasse:
<?php
// Eine Referenz zur Singleton-Instanz von Zend_Auth erhalten
require_once 'Zend/Auth.php';
$auth = Zend_Auth::getInstance();
// Authentifizierungs Adapter erstellen
$authAdapter = new MyAuthAdapter($username, $password);
// Authentifizierungs Versuch, das Ergebnis abspeichern
$result = $auth->authenticate($authAdapter);
if (!$result->isValid()) {
// Authentifizierung fehlgeschlagen; die genauen Gründe ausgeben
foreach ($result->getMessages() as $message) {
echo "$message\n";
}
} else {
// Authentifizierung erfolgreich; die Identität ($username) wird in der Session gespeichert
// $result->getIdentity() === $auth->getIdentity()
// $result->getIdentity() === $username
}
Sobald die Authentifizierung in einer Anfrage durchgeführt wurde, so wie im obigen Beispiel, ist es sehr einfach zu Prüfen ob eine erfolgreich authentifizierte Identität existiert:
<?php
$auth = Zend_Auth::getInstance();
if ($auth->hasIdentity()) {
// Identität existiert; auslesen
$identity = $auth->getIdentity();
}
Um eine Identität vom persistenten Speicher zu entfernen muß einfach die clearIdentity()
Methode verwendet werden. Das würde typischerweise für die Implementierung einer "Abmelde" Operation
in einer Anwendung Verwendung finden.
<?php
Zend_Auth::getInstance()->clearIdentity();
Wenn die automatische Verwendung von persistenten Speichern für einen bestimmten Verwendungszweck
unangebracht ist, kann ein Entwickler einfach die Verwendung der Zend_Auth Klasse
umgehen, und eine Adapter Klasse direkt verwenden. Die direkte Verwendung einer Adapterklasse
enthält das Konfigurieren und Vorbereiten eines Adapter Objektes und den Aufruf dessen
authenticate() Methode. Adapter-spezifische Details werden in der Dokumentation
jeden Adapters besprochen. Das folgende Beispeil verwendet MyAuthAdapter direkt:
<?php
// Den Authentifizierungs Adapter erstellen
$authAdapter = new MyAuthAdapter($username, $password);
// Authentifizierungs Versuch, speichere das Ergebnis
$result = $authAdapter->authenticate();
if (!$result->isValid()) {
// Authentifizierung fehlgeschlagen; die genauen Gründe ausgeben
foreach ($result->getMessages() as $message) {
echo "$message\n";
}
} else {
// Authentifizierung erfolgreich
// $result->getIdentity() === $username
}
Welcome!
Welcome to ZFResource - The Resource for the Zend Framework.
As you see, the website is in still in progress. Many features ( like Code Directory, Code Samples, User written Tutorials, Examples and News,...) will be online in near future.
At the moment, you can search and browse the manual in your language of
choice. Don't forget to come back later to benefit from the new features.
Help Wanted:
We are still searching for people want to help building this site. If you want to see this website in your language or you have any suggestions for this site please send us an email
![[Anmerkung]](images/note.png)
