MsiQueryFeatureStateExA 함수(msi.h)

MsiQueryFeatureStateEx 함수는 제품 기능에 대해 설치된 상태를 반환합니다. 이 함수는 컴퓨터 계정 아래에 설치된 제품의 instance 기능 또는 현재 사용자 계정 아래의 컨텍스트 또는 현재 사용자 이외의 사용자 계정에서 사용자별 관리되는 컨텍스트를 쿼리하는 데 사용할 수 있습니다. 현재 사용자 이외의 사용자에 대해 설치된 제품에 대한 정보를 얻으려면 사용자에게 관리 권한이 있어야 합니다.

구문

UINT MsiQueryFeatureStateExA(
  [in]            LPCSTR            szProductCode,
  [in]            LPCSTR            szUserSid,
  [in]            MSIINSTALLCONTEXT dwContext,
  [in]            LPCSTR            szFeature,
  [out, optional] INSTALLSTATE      *pdwState
);

매개 변수

[in] szProductCode

Productcode 관심 있는 기능이 포함된 제품의 GUID입니다.

[in] szUserSid

쿼리되는 제품의 instance 있는 계정의 SID(보안 식별자)를 지정합니다. dwContextMSIINSTALLCONTEXT_MACHINE 않으면 null 값이 현재 사용자를 지정합니다.

SID 유형 의미
NULL
NULL은 현재 로그온한 사용자를 표시합니다.
사용자 SID
시스템의 특정 사용자에 대한 열거형을 지정합니다. 사용자 SID의 예는 "S-1-3-64-2415071341-1358098788-3127455600-2561"입니다.
 
참고 특수 SID 문자열 s-1-5-18(시스템)은 컴퓨터별로 설치된 제품의 기능을 열거하는 데 사용할 수 없습니다. dwContextMSIINSTALLCONTEXT_MACHINE 경우 szUserSid는 null이어야 합니다.
 

[in] dwContext

쿼리 중인 제품의 설치 컨텍스트 instance.

Name 의미
MSIINSTALLCONTEXT_USERMANAGED
제품의 사용자별 관리 instance 대한 기능 상태를 검색합니다.
MSIINSTALLCONTEXT_USERUNMANAGED
제품의 사용자별 관리되지 않는 instance 대한 기능 상태를 검색합니다.
참고 쿼리가 현재 사용자 이외의 사용자 계정에 대한 사용자별 관리되지 않는 컨텍스트 아래에 설치된 제품에 대해 만들어지면 함수가 실패합니다.
 
MSIINSTALLCONTEXT_MACHINE
제품의 컴퓨터별 instance 대한 기능 상태를 검색합니다.

[in] szFeature

쿼리할 기능을 지정합니다. 기능 테이블의 기능 열에 있는 기능의 식별자입니다.

[out, optional] pdwState

지정된 제품 instance 대한 기능의 설치 상태입니다. 이 매개 변수는 다음 또는 null 중 하나를 반환할 수 있습니다.

의미
INSTALLSTATE_ADVERTISED
이 기능은 보급됩니다.
INSTALLSTATE_LOCAL
기능은 로컬로 설치됩니다.
INSTALLSTATE_SOURCE
이 기능은 원본에서 실행되도록 설치됩니다.

반환 값

MsiQueryFeatureStateEx 함수는 다음 값을 반환합니다.

의미
ERROR_ACCESS_DENIED
현재 사용자 이외의 사용자에 대해 설치된 제품에 대한 정보를 얻으려면 사용자에게 관리 권한이 있어야 합니다.
ERROR_BAD_CONFIGURATION
구성 데이터가 손상되었습니다.
ERROR_INVALID_PARAMETER
잘못된 매개 변수가 함수에 전달되었습니다.
ERROR_SUCCESS
함수가 성공적으로 완료되었습니다.
ERROR_UNKNOWN_FEATURE
기능 ID는 알려진 기능을 식별하지 않습니다.
ERROR_UNKNOWN_PRODUCT
제품 코드는 알려진 제품을 식별하지 않습니다.
ERROR_FUNCTION_FAILED
예기치 않은 내부 오류입니다.
 

자세한 내용은 표시된 오류 메시지를 참조하세요.

설명

MsiQueryFeatureStateEx 함수는 이 기능에 실제로 액세스할 수 있는지 확인하지 않습니다. MsiQueryFeatureStateEx 함수는 기능 ID의 유효성을 검사하지 않습니다. 수 없는 기능 ID에 대해 ERROR_UNKNOWN_FEATURE 반환됩니다. 쿼리가 현재 사용자 이외의 사용자 계정에 대한 사용자별 관리되지 않는 컨텍스트 아래에 설치된 제품에 대해 만들어지면 함수가 실패합니다. 이 경우 함수는 ERROR_UNKNOWN_FEATURE 반환하거나 제품이 보급된 경우(설치되지 않음) ERROR_UNKNOWN_PRODUCT 반환됩니다.

참고

msi.h 헤더는 MSiQueryFeatureStateEx를 유니코드 전처리기 상수의 정의에 따라 이 함수의 ANSI 또는 유니코드 버전을 자동으로 선택하는 별칭으로 정의합니다. 인코딩 중립 별칭을 인코딩 중립이 아닌 코드와 혼합하면 컴파일 또는 런타임 오류가 발생하는 불일치가 발생할 수 있습니다. 자세한 내용은 함수 프로토타입에 대한 규칙을 참조하세요.

요구 사항

요구 사항
지원되는 최소 클라이언트 Windows Server 2012, Windows 8, Windows Server 2008 R2 또는 Windows 7의 Windows Installer 5.0. Windows Server 2008 또는 Windows Vista의 Windows Installer 4.0 또는 Windows Installer 4.5. Windows Installer 버전에 필요한 최소 Windows 서비스 팩에 대한 자세한 내용은 Windows Installer 런타임 요구 사항을 참조하세요.
대상 플랫폼 Windows
헤더 msi.h
라이브러리 Msi.lib
DLL Msi.dll

추가 정보

표시된 오류 메시지

Feature 테이블

MsiQueryFeatureState

Windows Installer 2.0 이하에서 지원되지 않음

ProductCode

시스템 상태 함수