Benutzerdefinierter Authentifizierungsmanager mit Spring Security und Java-Konfiguration

Jeff I:

Ich verwende Spring Security mit SpringMVC, um eine Webanwendung zu erstellen (ich werde dies aus Gründen der Übersichtlichkeit als WebApp bezeichnen), die mit einer vorhandenen Anwendung spricht (ich werde dies als BackendApp bezeichnen).

Ich möchte Authentifizierungsverantwortlichkeiten an die BackendApp delegieren (damit ich die beiden Anwendungen nicht synchronisieren muss).

Um dies zu implementieren, möchte ich, dass die WebApp (Running Spring Security) über REST mit dem vom Benutzer angegebenen Benutzernamen und Kennwort in einer Form mit der BackendApp kommuniziert und sich basierend darauf authentifiziert, ob die Antwort der BackendApp 200 OK oder 401 Unauthorized lautet.

Ich verstehe, dass ich einen benutzerdefinierten Authentifizierungs-Manager schreiben muss, um dies zu tun. Ich bin jedoch sehr neu in Spring und kann keine Informationen zur Implementierung finden.

Ich glaube, ich muss so etwas tun:

public class CustomAuthenticationManager implements AuthenticationManager{

    @Override
    public Authentication authenticate(Authentication authentication) throws AuthenticationException {

        String username = authentication.getName();
        String pw       = authentication.getCredentials().toString();

        // Code to make rest call here and check for OK or Unauthorised.
        // What do I return?

    }

}

Setze ich authentication.setAuthenticated (true), wenn dies erfolgreich ist, und false, wenn dies nicht der Fall ist?

Wie konfiguriere ich die Federsicherheit nach dem Schreiben, um diesen Authentifizierungsmanager mithilfe einer Java-Konfigurationsdatei zu verwenden?

Vielen Dank im Voraus für jede Hilfe.

Halko Karr-Sajtarevic:

Schauen Sie sich mein Beispiel unten an. Sie müssen ein UsernamePasswordAuthenticationToken zurückgeben. Es enthält den Principal und die GrantedAuthorities. Hoffe ich konnte helfen :)

public Authentication authenticate(Authentication authentication) throws AuthenticationException {
    String username = authentication.getPrincipal() + "";
    String password = authentication.getCredentials() + "";

    User user = userRepo.findOne(username);
    if (user == null) {
        throw new BadCredentialsException("1000");
    }
    if (!encoder.matches(password, user.getPassword())) {
        throw new BadCredentialsException("1000");
    }
    if (user.isDisabled()) {
        throw new DisabledException("1001");
    }
    List<Right> userRights = rightRepo.getUserRights(username);
    return new UsernamePasswordAuthenticationToken(username, null, userRights.stream().map(x -> new SimpleGrantedAuthority(x.getName())).collect(Collectors.toList()));
}

PS: userRepo und rightRepo sind Spring-Data-JPA-Repositorys, die auf meine benutzerdefinierte Benutzer-DB zugreifen

SpringSecurity JavaConfig:

@Configuration
@EnableWebMvcSecurity
public class MySecurityConfiguration extends WebSecurityConfigurerAdapter {

public MySecurityConfiguration() {
    super(false);
}

@Override
protected AuthenticationManager authenticationManager() throws Exception {
    return new ProviderManager(Arrays.asList((AuthenticationProvider) new AuthProvider()));
}

}

Dieser Artikel stammt aus dem Internet. Bitte geben Sie beim Nachdruck die Quelle an.

Bei Verstößen wenden Sie sich bitte [email protected] Löschen.

bearbeiten am
0

Lass mich ein paar Worte sagen

0Kommentare
LoginNach der Teilnahme an der Überprüfung

Verwandte Artikel

TOP Liste

  1. 1

    So legen Sie mit dem Interface Builder unterschiedliche führende Speicherplätze für unterschiedliche Geräte fest

  2. 2

    Wie konvertiere ich einen Vektor von Bytes (u8) in eine Zeichenfolge?

  3. 3

    Wie kann ich in SCSS mehrere Klassen zu einer einzigen kombinieren?

  4. 4

    Eclipse Oxygen - Projekte verschwinden

  5. 5

    Wie konvertiert man einen Datenrahmen im langen Format in eine Liste mit einem geeigneten Format?

  6. 6

    Wie kann ich den Kaskadenmodus global einstellen?

  7. 7

    Wie erstelle ich einen neuen übergeordneten Knoten außerhalb der .ref (/ path) in der Firebase-Echtzeitdatenbank mithilfe von Cloud-Funktionen (Typescript)?

  8. 8

    So erhalten Sie eine gleichmäßige Höhe für alle Eingabefelder

  9. 9

    Python: Spalten mit demselben Namen zusammenführen, wobei der Mindestwert beibehalten wird

  10. 10

    Speichern Sie ein MPAndroidChart-Diagramm in einem Bild, ohne es in einer Aktivität anzuzeigen

  11. 11

    Gruppieren Sie Datenrahmenspalten nach ihrem Datum (die Spaltentitel enthalten) und fassen Sie die Instanzen von Einsen und Nullen in R . zusammen

  12. 12

    ElasticSearch BulkShardRequest ist aufgrund von org.elasticsearch.common.util.concurrent.EsThreadPoolExecutor fehlgeschlagen

  13. 13

    Tic Tac Toe-Spiel im React-Reset-Button funktioniert nicht

  14. 14

    Tomcat - Leiten Sie den alten Kontextstamm zum neuen Kontextstamm um

  15. 15

    Wie wählt man Unterschiede mit drei Tabellen aus?

  16. 16

    Ärgerliches Problem mit yaml, das ich nicht lösen kann

  17. 17

    Wie kann ich meine Tabelle abfragen, um sie in mySQL nach 2 Feldern zu gruppieren?

  18. 18

    So berechnen Sie die Verfügbarkeit von Anwendungen (SLA)

  19. 19

    Fügen Sie eine weitere Schaltfläche zu gwt Suggest Box hinzu

  20. 20

    Modbus Python Schneider PM5300

  21. 21

    Wie kann eine gleichmäßige Lastverteilung in ElasticSearch mit Indizes mit unterschiedlicher Anzahl von Shards erreicht werden?

heißlabel

Archiv