다음을 통해 공유


IHostSecurityManager::OpenThreadToken 메서드

현재 실행 중인 스레드와 연결된 임의 액세스 토큰을 엽니다.

구문

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

매개 변수

dwDesiredAccess
[in] 스레드 토큰에 대한 요청된 액세스 형식을 지정하는 액세스 값의 마스크입니다. 이러한 값은 Win32 OpenThreadToken 함수에서 정의됩니다. 요청된 액세스 형식은 토큰의 DACL(임의 액세스 제어 목록)과 조정되어 부여 또는 거부할 액세스 형식을 결정합니다.

bOpenAsSelf
[in] 호출 스레드에 대한 프로세스의 보안 컨텍스트를 사용하여 액세스 검사를 수행해야 함을 지정하려면 true이며, 호출 스레드 자체에 대한 보안 컨텍스트를 사용하여 액세스 검사를 수행해야 함을 지정하려면 false입니다. 스레드가 클라이언트를 가장하는 경우 보안 컨텍스트는 클라이언트 프로세스의 보안 컨텍스트일 수 있습니다.

phThreadToken
[out] 새로 열린 액세스 토큰에 대한 포인터입니다.

Return Value

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 함수가 호출자가 핸들을 임의의 스레드에 전달할 수 있도록 허용하는 반면 IHostSecurityManager::OpenThreadToken은 호출 스레드와 연결된 토큰만 여는 점을 제외하고 동일한 이름의 해당 Win32 함수와 유사하게 작동합니다.

HANDLE 형식은 COM과 호환되지 않습니다. 즉, 해당 크기는 운영 체제에 따라 다르며 사용자 지정 마샬링이 필요합니다. 따라서 이 토큰은 CLR과 호스트 사이의 프로세스 내에서만 사용됩니다.

요구 사항

플랫폼:시스템 요구 사항을 참조하세요.

헤더: MSCorEE.h

라이브러리: 리소스로 MSCorEE.dll에 포함됩니다.

.NET Framework 버전: 2.0부터 사용 가능

참고 항목