Heim >Java >Ist es möglich, Rollen von ServerWebExchange abzurufen?

Ist es möglich, Rollen von ServerWebExchange abzurufen?

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBnach vorne
2024-02-11 13:24:08394Durchsuche

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.

Frageninhalt

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 */

Workaround

Ich habe es in authentication。就我而言,主体实际上是 usernamepasswordauthenticationtoken,即 authentication Untertyp

umgewandelt
((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!

Stellungnahme:
Dieser Artikel ist reproduziert unter:stackoverflow.com. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen