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