Konfigurieren von Gruppenansprüchen und App-Rollen in Token
In diesem Artikel können Sie Ihre Apps mit App-Rollendefinitionen konfigurieren und App-Rollen Sicherheitsgruppen zuweisen, sodass Sie Flexibilität und Kontrolle verbessern und gleichzeitig die Anwendungssicherheit mit geringsten Berechtigungen erhöhen können.
Microsoft Entra ID unterstützt das Senden von zugewiesenen Sicherheitsgruppen, Microsoft Entra-Verzeichnisrollen und Verteilergruppen als Ansprüche in einem Token. Sie können diesen Ansatz verwenden, um die Autorisierung in Apps zu fördern. Microsoft Entra ID beschränkt jedoch die Gruppenunterstützung in einem Token durch die Größe des Tokens. Wenn der Benutzer mitglied von zu vielen Gruppen ist, gibt es keine Gruppen im Token.
In diesem Artikel lernen Sie einen alternativen Ansatz zum Abrufen von Benutzerinformationen in Token mithilfe des Microsoft Entra-Gruppensupports kennen. Stattdessen konfigurieren Sie Ihre Apps mit App-Rollendefinitionen und weisen App-Rollen Gruppen zu. Diese bewährte Methode für Zero Trust-Entwicklung verbessert Flexibilität und Kontrolle und erhöht gleichzeitig die Anwendungssicherheit mit geringsten Berechtigungen.
Sie können Gruppenansprüche in Token konfigurieren, die Sie in Ihren Anwendungen für die Autorisierung verwenden können. Denken Sie daran, dass Gruppeninformationen im Token nur aktuell sind, wenn Sie das Token empfangen. Gruppenbehauptungen unterstützen zwei Hauptmuster:
- Gruppen, die durch das Attribut ihres Microsoft Entra-Objektbezeichners (OID) identifiziert werden.
- Gruppen, die durch das attribut
sAMAccountName
oderGroupSID
für Active Directory-synchronisierte Gruppen und Benutzer identifiziert werden.
Die Gruppenmitgliedschaft kann Autorisierungsentscheidungen fördern. Das folgende Beispiel zeigt einige Ansprüche in einem Token. Sie können Gruppenansprüche und Rollen entweder zu ID- oder Zugriffstoken hinzufügen.
"aud": "00001111-aaaa-2222-bbbb-3333cccc4444",
"iss": "https://login.microsoftonline.com/833ced3d-cb2e-41de-92f1-29e2af035ddc/v2.0",
"iat": 1669657224, "nbf": 1669657224, "exp": 1669661124,
"groups": [
"0760b6cf-170e-4a14-91b3-4b78e0739963",
"3b2b0c93-acd8-4208-8eba-7a48db1cd4c0"
],
"oid": "aaaaaaaa-0000-1111-2222-bbbbbbbbbbbb",
"sub": "3OBtLXUC2ZrN_ADLNjW9X4o0lcd61py7lgHw3Skh77s",
"tid": "bbbbcccc-1111-dddd-2222-eeee3333ffff",
"ver": "2.0",
"wids": [
"cf1c38e5-3621-4004-a7cb-879624dced7c",
"b79fbf4d-3ef9-4689-8143-76b194e85509"
]
Das groups
Anspruchsarray besteht aus den IDs der Gruppen, in denen dieser Benutzer Mitglied ist. Das wids
Array besteht aus den IDs der Microsoft Entra-Rollen, die diesem Benutzer zugewiesen sind. Hier zeigt cf1c38e5-3621-4004-a7cb-879624dced7c
, dass die zugewiesenen Rollen dieses Benutzers Anwendungsentwickler und Standardmitglied enthalten, wie 3b2b0c93-acd8-4208-8eba-7a48db1cd4c0
angibt.
Ihre App kann Autorisierungsentscheidungen basierend auf dem Vorhandensein oder Fehlen dieser Ansprüche und deren Werte treffen. Sehen Sie in den integrierten Microsoft Entra-Rollen eine Liste der Werte für den wids
Anspruch.
Wenn Sie groups
und wids
-Ansprüche Ihrem Token hinzufügen möchten, wählen Sie Alle Gruppen aus, wie im folgenden Beispiel der App-Registrierungen | Token-Konfiguration | Optionale Ansprüche | Gruppenansprüche bearbeiten angezeigt.
Gruppenübergänge
Wenn Sie alle Gruppen in Ihrem Token anfordern, wie im obigen Beispiel gezeigt, können Sie sich nicht darauf verlassen, dass das Token den groups
Anspruch in Ihrem Token hat. Es gibt Größenbeschränkungen für Token und für groups
Ansprüche, damit sie nicht zu groß werden. Wenn der Benutzer mitglied von zu vielen Gruppen ist, muss Ihre App die Gruppenmitgliedschaft des Benutzers aus Microsoft Graph abrufen. Die Grenzwerte für Gruppen in einem groups
Anspruch sind:
- 200 Gruppen für JSON-Webtoken (JWT).
- 150 Gruppen für SAML-Token (Security Assertion Markup Language).
- 6 Gruppen bei Verwendung des impliziten Flusses (z. B. mithilfe des ASP.NET-Kerns, der ID-Token über den impliziten Flussteil eines Hybridflusses abruft).
- Der Implicit Flow wird für Single-Page-Webanwendungen nicht mehr empfohlen.
- In einem OAuth2-Hybridablauf kann ein impliziter Fluss nur in Web-Apps für das ID-Token verwendet werden, niemals das Zugriffstoken.
Wenn Sie OpenID Connect oder OAuth2 verwenden, können Sie bis zu 200 Gruppen in Ihrem Token haben. Wenn Sie SAML verwenden, können Sie nur über 150 Gruppen verfügen, da SAML-Token größer als OAuth2- und OpenID Connect-Token sind. Wenn Sie den impliziten Fluss verwenden, beträgt der Grenzwert sechs, da diese Antworten in der URL angezeigt werden. In all diesen Fällen wird anstelle eines groups
-Anspruchs ein Hinweis (als Gruppenüberlastung bezeichnet) angezeigt, der Sie informiert, dass der Benutzer Mitglied von zu vielen Gruppen ist, die in Ihr Token passen.
Der groups
Anspruch soll src1
zugeordnet werden. Theoretisch suchen Sie dann nach dem _claim_sources
Anspruch und dann suchen Sie das src1
Mitglied. Von dort aus finden Sie die Graph-Abfrage, die Sie zum Abrufen der Gruppenmitgliedschaft verwenden. Es gibt jedoch ein Problem mit dem, was Sie in der Beispieldiagrammabfrage sehen. Es bezieht sich auf Azure AD Graph (das von Microsoft abgekündigt wird), verwenden Sie es daher nicht.
Implizite Flussüberlastungsanzeige erfolgt mit einem hasgroups
-Anspruch anstelle des groups
-Anspruchs.
Um die ordnungsgemäße Autorisierung mithilfe der Gruppenmitgliedschaft sicherzustellen, überprüfen Sie, ob Ihre App den groups
-Anspruch hat. Wenn vorhanden, verwenden Sie diesen Anspruch, um die Gruppenmitgliedschaft des Benutzers zu ermitteln. Wenn kein groups
-Anspruch vorhanden ist, überprüfen Sie, ob ein hasgroups
-Anspruch oder ein _claim_names
-Anspruch mit einem groups
-Element des Arrays vorhanden ist. Wenn eine dieser Ansprüche vorhanden ist, ist der Benutzer Mitglied von zu vielen Gruppen für das Token. In diesem Fall muss Ihre App Microsoft Graph verwenden, um die Gruppenmitgliedschaft für den Benutzer zu ermitteln. Siehe Auflisten der Mitgliedschaften eines Benutzers (direkt und transitiv), um alle Gruppen zu finden, sowohl direkt als auch transitiv, bei denen der Benutzer Mitglied ist.
Wenn Ihre Anwendung Informationen zur Gruppenmitgliedschaft in Echtzeit benötigt, verwenden Sie Microsoft Graph, um die Gruppenmitgliedschaft zu ermitteln. Denken Sie daran, dass die Informationen des Tokens nur zum Zeitpunkt des Erhalts auf dem neuesten Stand sind.
Sehen Sie sich das folgende Beispiel für die App-Registrierungen | Token-Konfiguration | Optionale Ansprüche | Gruppenansprüche bearbeiten den Anspruchsbildschirm an. Eine Möglichkeit zum Vermeiden des Zugriffs auf einen Gruppenüberlastungsanspruch besteht darin, Gruppen auszuwählen, die der Anwendung auf dem „Gruppenanspruch bearbeiten“- Bildschirm anstelle von „Alle Gruppen“" zugewiesen sind.
Wenn Sie Gruppen auswählen, die der Anwendung zugewiesen sind, wird eine Gruppe in den groups
Anspruch eingeschlossen, wenn die folgenden Bedingungen erfüllt sind:
- die Gruppe ist der Enterprise-App zugewiesen
- Der Benutzer ist ein direktes Mitglied der Gruppe.
Ab der Veröffentlichung dieses Artikels unterstützen die Gruppen, die der Anwendungsoption zugewiesen sind, unterstützen keine indirekte Mitgliedschaft. Für die Gruppenzuweisung ist mindestens eine P1-Level-Lizenz erforderlich. Ein kostenloser Mandant kann einer Anwendung keine Gruppen zuweisen.
Gruppen und App-Rollen
Eine weitere Möglichkeit, das Problem der Gruppenüberlastung zu vermeiden, besteht darin, dass die App Rollen definiert, die Benutzer und Gruppen als Mitgliedertypen zulassen. Wie im folgenden Beispiel der App-Registrierungen | App-Rollen | App-Rollen erstellen auf dem Bildschirm gezeigt, wählen Sie Benutzer/Gruppen für zulässige Mitgliedstypen aus.
Nach dem Erstellen der App-Rolle in der Registrierung der App können die IT-Profis der Rolle Benutzer und Gruppen zuweisen. Ihre App erhält einen roles
-Anspruch in Ihrem Token (ID-Token für App, Zugriffstoken für APIs) mit allen zugewiesenen Rollen des angemeldeten Benutzers, wie im folgenden Tokenbeispiel gezeigt.
"aud": "11112222-bbbb-3333-cccc-4444dddd5555",
"iss": "https://login.microsoftonline.com/833ced3d-cb2e-41de-92f1-29e2af035ddc/v2.0",
"iat": 1670826509, "nbf": 1670826509, "exp": 1670830409,
"name": "Kyle Marsh",
"oid": "bbbbbbbb-1111-2222-3333-cccccccccccc",
"preferred_username": "kylemar@idfordevs.dev",
"roles": [
"Approver",
"Reviewer"
],
"sub": "dx-4lf-0loB3c3uVrULnZ2VTLuRRWYff0q7-QlIfYU4",
"tid": "ccccdddd-2222-eeee-3333-ffff4444aaaa",
Denken Sie daran, dass Ihre Anwendung die folgenden Bedingungen behandelt:
- fehlender
roles
Anspruch - Benutzer hat keine Rollenzuweisung
- mehrere Werte im
roles
-Anspruch, wenn der Benutzer mehrere Rollenzuweisungen hat
Wenn Sie App-Rollen erstellen, die Benutzer und Gruppen als Mitglieder zulassen, definieren Sie immer eine grundlegende Benutzerrolle ohne erhöhte Autorisierungsrollen. Wenn eine Enterprise-App-Konfiguration eine Zuweisung erfordert, können nur Benutzer mit direkter Zuweisung zu einer Anwendung oder Mitgliedschaft in einer Gruppe, die der App zugewiesen ist, die App verwenden.
Wenn Ihre App App-Rollen festgelegt hat, die Benutzern und Gruppen die Mitgliedschaft gewähren, muss bei der Zuweisung eines Benutzers oder einer Gruppe zur App eine der festgelegten App-Rollen Teil dieser Zuweisung sein. Wenn Ihre App nur erhöhte Rollen (z. B. admin
) für die App definiert hat, wird allen Benutzern und Gruppen die Administratorrolle zugewiesen. Wenn Sie eine Basisrolle (z. B. user
) definieren, können Benutzern und Gruppen, die der App zugewiesen sind, die Basisbenutzerrolle zugewiesen werden.
Durch die Verwendung von Rollen lassen sich nicht nur Überschreitungsansprüche für Gruppen vermeiden. Ein weiterer Vorteil besteht darin, dass keine Zuordnung zwischen einer Gruppen-ID oder einem Gruppennamen und ihrem/seinem Zweck in der App erforderlich ist. Beispielsweise kann Ihr Code nach dem Administratorrollenanspruch suchen, anstatt Gruppen in den groups
Ansprüchen zu durchlaufen und zu entscheiden, welche Gruppen-IDs die Administratorfunktionalität zulassen sollen.
Überprüfen und Verwenden von Rollen in Ihrem Code
Wenn Sie App-Rollen für Ihre App definieren, liegt es in Ihrer Verantwortung, Autorisierungslogik für diese Rollen zu implementieren. Lesen Sie Implementieren der rollenbasierten Zugriffssteuerung in Anwendungen, um zu erfahren, wie Sie Autorisierungslogik in Ihren Apps implementieren können.
Nächste Schritte
- Anpassen von Token beschreibt die Informationen, die Sie in Microsoft Entra-Token empfangen können. Es wird erläutert, wie Token angepasst werden, um Flexibilität und Kontrolle zu verbessern und gleichzeitig die Zero-Trust-Sicherheit der Anwendung mit dem Prinzip der geringsten Privilegien zu erhöhen.
- Konfigurieren von Gruppenansprüchen für Anwendungen mithilfe der Microsoft Entra ID zeigt, wie Microsoft Entra-ID die Gruppenmitgliedschaftsinformationen eines Benutzers in Token für die Verwendung in Anwendungen bereitstellen kann.
- Bewährte Sicherheitsmethoden für Anwendungseigenschaften beschreibt die Umleitungs-URI, Zugriffstoken (verwendet für implizite Abläufe), Zertifikate und geheime Schlüssel, Anwendungs-ID-URI und Anwendungsbesitz.
- Microsoft Identity Platform-Bereiche, Berechtigungen, & Zustimmung erläutert die grundlegenden Konzepte des Zugriffs und der Autorisierung, die Ihnen helfen, sicherere und vertrauenswürdigere Anwendungen zu erstellen.
- Verwenden Sie Zero Trust Identity and Access Management Development Best Practices in Ihrem Anwendungsentwicklungslebenszyklus, um sichere Anwendungen zu erstellen.