다음을 통해 공유


IHostSecurityManager::SetSecurityContext 메서드

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

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

매개 변수

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

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

반환 값

HRESULT

설명

S_OK

SetSecurityContext에서 성공적으로 반환되었습니다.

HOST_E_CLRNOTAVAILABLE

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를 구현하는 경우 CLR은 호스트가 ICLRIoCompletionManager::OnComplete를 호출한 후에 SetSecurityContext를 호출합니다.

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

요구 사항

플랫폼: .NET Framework 시스템 요구 사항 참조

헤더: MSCorEE.h

라이브러리: MSCorEE.dll에 리소스로 포함됨

.NET Framework 버전: 4, 3.5 SP1, 3.5, 3.0 SP1, 3.0, 2.0 SP1, 2.0

참고 항목

참조

EContextType 열거형

ICLRIoCompletionManager 인터페이스

IHostIoCompletionManager 인터페이스

IHostSecurityContext 인터페이스

IHostSecurityManager 인터페이스

IHostThreadPoolManager 인터페이스

System.Threading.ThreadPool