Comment : créer une revendication personnalisée
L'infrastructure de modèle d'identité dans Windows Communication Foundation (WCF) fournit un ensemble de types et droits de revendication intégrés avec des fonctions d'assistance pour créer des instances Claim avec ces types et droits. Ces revendications intégrées sont conçues pour modeler données trouvées dans les types d'informations d'identification du client que WCF prend en charge par défaut. Dans la plupart des cas, les revendications intégrées sont suffisantes ; toutefois, certaines applications peuvent requérir des revendications personnalisées. Une revendication comporte trois volets : le type de revendication, la ressource à laquelle la revendication s'applique et le droit revendiqué sur cette ressource. Cette rubrique décrit comment créer une revendication personnalisée.
Pour créer une revendication personnalisée basée sur un type de données primitif
Créez une revendication personnalisée en passant le type de revendication, la valeur de la ressource et le droit sur la ressource au constructeur Claim.
- Choisissez une valeur unique pour le type de revendication.
Le type de revendication est un identificateur de chaîne unique. Il incombe au concepteur de la revendication personnalisée de vérifier que l'identificateur de chaîne utilisé pour le type de revendication est unique. Pour obtenir une liste des types de revendications définis par WCF, consultez la classe ClaimTypes. - Choisissez le type de données primitif et la valeur de la ressource.
Une ressource est un objet. Le type CLR de la ressource peut être une primitive, telle que String ou Int32, ou tout type sérialisable. Le type CLR de la ressource doit être sérialisable, car les revendications sont sérialisées en différents points par WCF. Les types primitifs sont sérialisables. - Choisissez un droit défini par WCF ou une valeur unique pour un droit personnalisé.
Un droit est un identificateur de chaîne unique. Les droits définis par WCF le sont dans la classe Rights.
Il incombe au concepteur de la revendication personnalisée de vérifier que l'identificateur de chaîne utilisé pour le droit est unique.
L'exemple de code suivant crée une revendication personnalisée avec un type de revendicationhttp://example.org/claims/simplecustomclaim
, pour une ressource nomméeDriver's License
, et avec le droit PossessProperty.
- Choisissez une valeur unique pour le type de revendication.
Pour créer une revendication personnalisée basée sur un type de données non primitif
Créez une revendication personnalisée en passant le type de revendication, la valeur de la ressource et le droit sur la ressource au constructeur Claim.
- Choisissez une valeur unique pour le type de revendication.
Le type de revendication est un identificateur de chaîne unique. Il incombe au concepteur de la revendication personnalisée de vérifier que l'identificateur de chaîne utilisé pour le type de revendication est unique. Pour obtenir une liste des types de revendications définis par WCF, consultez la classe ClaimTypes. - Choisissez ou définissez un type non primitif sérialisable pour la ressource.
Une ressource est un objet. Le type CLR de la ressource doit être sérialisable, car les revendications sont sérialisées en différents points par WCF. Les types primitifs sont déjà sérialisables.
Lorsqu'un nouveau type est défini, appliquez DataContractAttribute à la classe. Appliquez également l'attribut DataMemberAttribute à tous les membres du nouveau type qui doivent être sérialisés dans le cadre de la revendication.
L'exemple de code suivant définit un type de ressource personnalisé nomméMyResourceType
. - Choisissez un droit défini par WCF ou une valeur unique pour un droit personnalisé.
Un droit est un identificateur de chaîne unique. Les droits définis par WCF le sont dans la classe Rights.
Il incombe au concepteur de la revendication personnalisée de vérifier que l'identificateur de chaîne utilisé pour le droit est unique.
L'exemple de code suivant crée une revendication personnalisée avec un type de revendicationhttp://example.org/claims/complexcustomclaim
, un type de ressource personnaliséMyResourceType
et avec le droit PossessProperty.
- Choisissez une valeur unique pour le type de revendication.
Exemple
L'exemple de code suivant montre comment créer une revendication personnalisée avec un type de ressource primitif et un type de ressource non primitif.
Voir aussi
Référence
Claim
Rights
ClaimTypes
DataContractAttribute
DataMemberAttribute
Concepts
Gestion des revendications et autorisation avec le modèle d'identité
Gestion des revendications et autorisation avec le modèle d'identité