IHostSecurityManager::OpenThreadToken 方法

打开与当前正在执行之线程关联的任意访问令牌。

语法

HRESULT OpenThreadToken (  
    [in]  DWORD    dwDesiredAccess,
    [in]  BOOL     bOpenAsSelf,
    [out] HANDLE   *phThreadToken  
);  

参数

dwDesiredAccess
[in] 指定请求的线程令牌访问权限类型之访问值的掩码。 这些值在 Win32 OpenThreadToken 函数中定义。 请求的访问权限类型要与令牌的自由访问控制列表 (DACL) 一致,以确定要授予或拒绝的访问权限的类型。

bOpenAsSelf
[in] true 指定应使用调用线程之进程的安全性上下文进行访问检查,false 指定应使用调用线程本身的安全性上下文来执行访问检查。 如果线程正在模拟客户端,安全性上下文可以是客户端进程的安全性上下文。

phThreadToken
[out] 指向新打开之访问令牌的指针。

返回值

HRESULT 说明
S_OK 已成功返回 OpenThreadToken
HOST_E_CLRNOTAVAILABLE 公共语言运行时 (CLR) 未加载到进程中,或 CLR 处于无法运行托管代码或无法成功处理调用的状态。
HOST_E_TIMEOUT 调用超时。
HOST_E_NOT_OWNER 调用方未持有锁。
HOST_E_ABANDONED 阻塞的线程或纤程正在等待某一事件,而该事件已被取消。
E_FAIL 发生未知的灾难性故障。 当方法返回 E_FAIL 时,进程中无法再使用 CLR。 后续调用承载方法会返回 HOST_E_CLRNOTAVAILABLE。

注解

IHostSecurityManager::OpenThreadToken 的行为类似于具有相同名称的对应 Win32 函数,只不过 Win32 函数允许调用方将句柄传入任意线程,同时 IHostSecurityManager::OpenThreadToken 仅打开与调用线程关联的令牌。

HANDLE 类型不符合 COM 要求,也就是说,其大小特定于操作系统,并需要自定义封送处理。 因此,此令牌仅在该进程内的 CLR 和主机之间使用。

要求

平台:请参阅系统要求

标头:MSCorEE.h

库:作为资源包含在 MSCorEE.dll 中

.NET Framework 版本:自 2.0 起可用

另请参阅