다음을 통해 공유


IHostSecurityManager::SetSecurityContext 메서드

현재 실행 중인 스레드의 보안 컨텍스트를 설정합니다.

구문

HRESULT SetSecurityContext (  
    [in]  EContextType eContextType,  
    [out] IHostSecurityContext** ppSecurityContext  
);  

매개 변수

eContextType
[in] CLR(공용 언어 런타임)이 호스트에 배치하는 컨텍스트 형식을 나타내는 EContextType 값 중 하나입니다.

ppSecurityContext
[out] 새 IHostSecurityContext 개체의 주소에 대한 포인터입니다.

Return Value

HRESULT 설명
S_OK SetSecurityContext가 성공적으로 반환되었습니다.
HOST_E_CLRNOTAVAILABLE CLR이 프로세스에 로드되지 않았거나 CLR이 관리 코드를 실행하거나 호출을 성공적으로 처리할 수 없는 상태입니다.
HOST_E_TIMEOUT 호출 시간이 초과되었습니다.
HOST_E_NOT_OWNER 호출자는 잠금을 소유하지 않습니다.
HOST_E_ABANDONED 차단된 스레드 또는 파이버가 이벤트를 기다리는 동안 이벤트가 취소되었습니다.
E_FAIL 알 수 없는 치명적인 오류가 발생했습니다. 메서드가 E_FAIL을 반환하면 CLR은 더 이상 프로세스 내에서 사용할 수 없습니다. 호스팅 메서드에 대한 후속 호출은 HOST_E_CLRNOTAVAILABLE을 반환합니다.

설명

CLR은 여러 시나리오에서 SetSecurityContext를 호출합니다. 클래스 및 모듈 생성자 및 종료자를 실행하기 전에 CLR은 SetSecurityContext를 호출하여 실행 실패로부터 호스트를 보호합니다. 그런 다음 SetSecurityContext에 대한 다른 호출을 사용하여 생성자 또는 종료자를 실행한 후 보안 컨텍스트를 원래 상태로 초기화합니다. I/O 완료에서도 유사한 패턴이 발생합니다. 호스트가 IHostIoCompletionManager를 구현하는 경우 호스트가 ICLRIoCompletionManager::OnComplete를 호출한 후 CLR이 SetSecurityContext를 호출합니다.

작업자 스레드의 비동기 지점에서 CLR은 호스트 또는 CLR이 스레드 풀을 구현하는지 여부에 따라 ThreadPool.QueueUserWorkItem 또는 IHostThreadPoolManager::QueueUserWorkItem 내에서 SetSecurityContext를 호출합니다.

요구 사항

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

헤더: MSCorEE.h

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

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

참고 항목