php-Editor Baicao beantwortet Ihre Frage: „Ist es möglich, Rollen von ServerWebExchange abzurufen?“ Die Antwort lautet „Ja“. In Spring WebFlux können die aktuell angeforderten Rolleninformationen über das ServerWebExchange-Objekt abgerufen werden. ServerWebExchange ist eine der Kernklassen des Spring WebFlux-Frameworks, das den Kontext von HTTP-Anfragen und -Antworten darstellt. Über das ServerWebExchange-Objekt können Sie auf Informationen wie den Anforderungspfad, Anforderungsheader und Anforderungsparameter zugreifen. Um Rolleninformationen zu erhalten, können Sie das aktuell angeforderte Benutzerobjekt über die Methode getUser() des ServerWebExchange-Objekts abrufen, um die Rolleninformationen des Benutzers abzurufen. Auf diese Weise können Sie basierend auf der Rolle des Benutzers eine entsprechende Berechtigungskontrolle und Geschäftsverarbeitung durchführen.
Ich kann den Hauptnamen aus der org.springframework.web.server.serverwebexchange
-Instanz abrufen.
exchange.getprincipal().subscribe(principal -> /* do something with it */);
Kann ich auch die Rolle des Schulleiters abrufen? java.security.principal
类(与 userdetails
不同)仅提供名称字符串 (getname()
)
Anwendungsfall: Nehmen wir an, ich möchte ein gatewayfilter
schreiben, das die Rolle des aktuellen Benutzers berücksichtigt und den Austausch ändert:
(exchange, chain) -> /* some filtering logic */
Ich habe es in authentication
。就我而言,主体实际上是 usernamepasswordauthenticationtoken
,即 authentication
Untertyp
((Authentication) principal).getAuthorities()
Das obige ist der detaillierte Inhalt vonIst es möglich, Rollen von ServerWebExchange abzurufen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!