Partager via


Fonction NtOpenThreadToken (ntifs.h)

La routine NtOpenThreadToken ouvre le jeton d’accès associé à un thread et retourne un handle qui peut être utilisé pour accéder à ce jeton.

Syntaxe

__kernel_entry NTSYSCALLAPI NTSTATUS NtOpenThreadToken(
  [in]  HANDLE      ThreadHandle,
  [in]  ACCESS_MASK DesiredAccess,
  [in]  BOOLEAN     OpenAsSelf,
  [out] PHANDLE     TokenHandle
);

Paramètres

[in] ThreadHandle

Gérez le thread dont le jeton d’accès doit être ouvert. Le handle doit avoir un accès THREAD_QUERY_INFORMATION. Utilisez la macro NtCurrentThread pour spécifier le thread actuel.

[in] DesiredAccess

ACCESS_MASK structure spécifiant les types d’accès demandés au jeton d’accès. Ces types d’accès demandés sont comparés à la liste de contrôle d’accès discrétionnaire du jeton (DACL) pour déterminer quels droits d’accès sont accordés ou refusés.

[in] OpenAsSelf

Valeur booléenne spécifiant si la vérification d’accès doit être effectuée sur le contexte de sécurité du thread appelant NtOpenThreadToken ou par rapport au contexte de sécurité du processus pour le thread appelant.

Si ce paramètre est FALSE, la vérification d’accès est effectuée à l’aide du contexte de sécurité du thread appelant. Si le thread emprunte l’identité d’un client, ce contexte de sécurité peut être celui d’un processus client. Si ce paramètre est TRUE, la vérification d’accès est effectuée à l’aide du contexte de sécurité du processus pour le thread appelant.

[out] TokenHandle

Pointeur vers une variable allouée par l’appelant qui reçoit un handle vers le jeton d’accès nouvellement ouvert.

Valeur de retour

NtOpenThreadToken retourne STATUS_SUCCESS ou un état d’erreur approprié. Les codes d’état d’erreur possibles sont les suivants :

Retourner le code Description
STATUS_ACCESS_DENIED
ThreadHandle n’a pas accès THREAD_QUERY_INFORMATION.
STATUS_CANT_OPEN_ANONYMOUS Le client a demandé le niveau d’emprunt d’identité SecurityAnonymous. Toutefois, un jeton anonyme ne peut pas être ouvert. Pour plus d’informations, consultez SECURITY_IMPERSONATION_LEVEL.
STATUS_INVALID_HANDLE ThreadHandle n’était pas un handle valide.
STATUS_NO_TOKEN Une tentative a été effectuée pour ouvrir un jeton associé à un thread qui n’emprunte pas actuellement l’identité d’un client.
STATUS_OBJECT_TYPE_MISMATCH threadHandle n’était pas un handle de thread.

Remarques

NtOpenThreadToken ouvre le jeton d’accès associé à un thread et retourne un handle pour ce jeton.

Le paramètre OpenAsSelf permet à un processus serveur d’ouvrir le jeton d’accès d’un processus client lorsque le processus client a spécifié le niveau d’emprunt d’identité SecurityIdentification pour le type énuméré SECURITY_IMPERSONATION_LEVEL. Sans ce paramètre, le processus appelant n’est pas en mesure d’ouvrir le jeton d’accès du client à l’aide du contexte de sécurité du client, car il est impossible d’ouvrir des objets de niveau exécutif à l’aide du niveau d’emprunt d’identité SecurityIdentification.

Tout handle obtenu en appelant NtOpenThreadToken doit finalement être libéré en appelant NtClose.

Pour plus d’informations sur la sécurité et le contrôle d’accès, consultez modèle de sécurité Windows pour les développeurs de pilotes et la documentation sur ces rubriques dans le Kit de développement logiciel (SDK) Windows.

Pour les appels à partir de pilotes en mode noyau, les versions NtXxx et ZwXxx d’une routine Windows Native System Services peuvent se comporter différemment de la façon dont elles gèrent et interprètent les paramètres d’entrée. Pour plus d’informations sur la relation entre les versions NtXxx et ZwXxx d’une routine, consultez Using Nt and Zw Versions of the Native System Services Routines.

Exigences

Exigence Valeur
client minimum pris en charge Windows XP
d’en-tête ntifs.h
bibliothèque NtosKrnl.lib
DLL NtosKrnl.exe

Voir aussi

ACCESS_MASK

de liste de contrôle d’accès

NtOpenThreadTokenEx

psDereferencePrimaryToken

SECURITY_IMPERSONATION_LEVEL

ZwClose

ZwOpenProcessTokenEx