Bedingte Lösung in Unity: Erkundung des Strategiemusters
Hintergrund
Bedingte Lösung ermöglicht es Ihnen um verschiedene Implementierungsklassen basierend auf bestimmten Bedingungen zu injizieren. Im gegebenen Szenario möchten Sie verschiedene Authentifizierungsanbieter basierend auf der Art der Authentifizierung (z. B. Twitter oder Facebook) bedingt auflösen.
Lösung: Implementierung des Strategiemusters
Ein empfohlener Ansatz ist die Verwendung des Strategiemusters. Dieses Muster entkoppelt die Authentifizierungslogik vom Controller und macht es einfach, Authentifizierungsanbieter hinzuzufügen oder zu entfernen, ohne das Design zu ändern.
Definieren der Schnittstellen
- IAuthenticate: Macht die Authentifizierungsmethode „Login“ verfügbar.
- IAuthenticateStrategy: Definiert die Schnittstelle für die Anmeldestrategie, die verschiedene Authentifizierungen verwaltet Anbieter.
Implementierung von Authentifizierungsanbietern
- TwitterAuth und FacebookAuth: Implementieren Sie die IAuthenticate-Schnittstelle und stellen Sie spezifische Anmeldeimplementierungen bereit.
- Darüber hinaus enthalten sie die Methode „AppliesTo“, die angibt, ob der Anbieter auf einen bestimmten Anbieternamen zutrifft (z. B. TwitterAuth). gilt für „TwitterAuth“).
Strategieimplementierung
- AuthenticateStrategy: Implementiert die IAuthenticateStrategy-Schnittstelle und verwaltet eine Reihe von Authentifizierungsanbietern.
- Die Anmeldemethode akzeptiert einen Anbieternamen und Benutzeranmeldeinformationen und wählt den entsprechenden Anbieter aus Gilt für.
Unity-Registrierung
Konfigurieren Sie Unity für die Registrierung der folgenden Typen:
- IAuthenticate-Implementierungen (TwitterAuth und FacebookAuth) mit eindeutige Instanznamen.
- IAuthenticateStrategy mit einem Injektionskonstruktor, der ein Array enthält von IAuthenticate-Instanzen.
Verwendung im Controller
- Injizieren Sie die IAuthenticateStrategy-Schnittstelle in den Controller-Konstruktor.
- Verwenden Sie die Anmeldung Methode der Strategie zur Durchführung von Anmeldevorgängen mit dem angegebenen Anbieter Name.
Alternative Option: Unity-Konfiguration
Alternativ können Sie die Typen direkt in Ihrer Datei „unity.config“ registrieren, anstatt die Unity-Containerprogrammierung zu verwenden.
Vorteile der bedingten Lösung mit dem Strategiemuster
-
Erweiterbarkeit: Einfaches Hinzufügen oder Entfernen von Authentifizierungsanbietern durch Aktualisieren der Unity-Konfiguration oder Hinzufügen neuer Strategieimplementierungen.
-
Entkopplung: Isoliert die Authentifizierungslogik von Der Controller ermöglicht eine flexible Verwaltung der Authentifizierungsanbieter.
-
Testbarkeit: Jeder Der Authentifizierungsanbieter kann dank der Schnittstellen des Strategiemusters unabhängig getestet werden.
Das obige ist der detaillierte Inhalt vonWie können die bedingte Auflösung und das Strategiemuster von Unity die Authentifizierungsanbieterverwaltung verbessern?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!