다음을 통해 공유


MsiEnumProductsExA 함수(msi.h)

MsiEnumProductsEx 함수는 지정된 컨텍스트에서 현재 보급되거나 설치된 제품의 하나 또는 모든 인스턴스를 열거합니다. 이 함수는 msiEnumProducts대체합니다.

통사론

UINT MsiEnumProductsExA(
  [in, optional]      LPCSTR            szProductCode,
  [in]                LPCSTR            szUserSid,
  [in]                DWORD             dwContext,
  [in]                DWORD             dwIndex,
  [out, optional]     CHAR [39]         szInstalledProductCode,
  [out, optional]     MSIINSTALLCONTEXT *pdwInstalledContext,
  [out, optional]     LPSTR             szSid,
  [in, out, optional] LPDWORD           pcchSid
);

매개 변수

[in, optional] szProductCode

ProductCode 열거할 제품의 GUID입니다. szUserSiddwContext 매개 변수로 지정된 컨텍스트 범위 내의 제품 인스턴스만 열거됩니다. 이 매개 변수는 NULL 설정하여 지정된 컨텍스트의 모든 제품을 열거할 수 있습니다.

[in] szUserSid

열거형의 컨텍스트를 제한하는 SID(보안 식별자)를 지정하는 Null로 끝나는 문자열입니다. 특수 SID 문자열 s-1-1-0(모두)은 시스템의 모든 사용자에 대한 열거형을 지정합니다. s-1-1-0 이외의 SID 값은 사용자-SID로 간주되며 현재 사용자 또는 시스템의 모든 사용자로 열거형을 제한합니다. 이 매개 변수는 NULL 설정하여 열거형 범위를 현재 사용자로 제한할 수 있습니다.

SID 유형 의미
NULL
현재 로그온한 사용자를 지정합니다.
사용자 SID
시스템의 특정 사용자에 대한 열거형을 지정합니다. 사용자 SID의 예는 "S-1-3-64-2415071341-1358098788-3127455600-2561"입니다.
s-1-1-0
시스템의 모든 사용자에 대한 열거형을 지정합니다.
 
참고 특수 SID 문자열 s-1-5-18(시스템)은 컴퓨터별로 설치된 제품 또는 패치를 열거하는 데 사용할 수 없습니다. dwContext MSIINSTALLCONTEXT_MACHINE만 설정되면 szUserSid NULL합니다.
 

[in] dwContext

열거형을 컨텍스트로 제한합니다. 이 매개 변수는 다음 표에 표시된 값 중 하나 또는 조합일 수 있습니다.

문맥 의미
MSIINSTALLCONTEXT_USERMANAGED
szUserSid지정된 사용자의 모든 사용자별 관리형 설치로 확장된 열거형입니다. 잘못된 SID는 항목을 반환하지 않습니다.
MSIINSTALLCONTEXT_USERUNMANAGED
szUserSid지정된 사용자에 대한 모든 사용자별 관리되지 않는 설치로 확장된 열거형입니다. 잘못된 SID는 항목을 반환하지 않습니다.
MSIINSTALLCONTEXT_MACHINE
모든 컴퓨터별 설치로 확장된 열거형입니다. dwInstallContext MSIINSTALLCONTEXT_MACHINE만 설정된 경우 szUserSID 매개 변수는 NULL합니다.

[in] dwIndex

검색할 제품의 인덱스를 지정합니다. 이 매개 변수는 MsiEnumProductsEx 함수에 대한 첫 번째 호출에 대해 0이어야 하며 이후 호출에 대해 증가해야 합니다. 인덱스는 이전 호출이 ERROR_SUCCESS 반환한 경우에만 증가해야 합니다. 제품은 주문되지 않으므로 모든 새 제품에는 임의 인덱스가 있습니다. 즉, 함수는 순서에 따라 제품을 반환할 수 있습니다.

[out, optional] szInstalledProductCode

열거 중인 제품 인스턴스의 ProductCode GUID를 제공하는 TCHAR Null로 끝나는 문자열입니다. 이 매개 변수는 NULL수 있습니다.

[out, optional] pdwInstalledContext

열거 중인 제품 인스턴스의 컨텍스트를 반환합니다. 출력 값은 MSIINSTALLCONTEXT_USERMANAGED, MSIINSTALLCONTEXT_USERUNMANAGED 또는 MSIINSTALLCONTEXT_MACHINE 수 있습니다. 이 매개 변수는 NULL수 있습니다.

[out, optional] szSid

이 제품 인스턴스가 있는 계정의 문자열 SID를 수신하는 출력 버퍼입니다. 이 버퍼는 컴퓨터별 컨텍스트에 설치된 인스턴스에 대해 빈 문자열을 반환합니다.

이 버퍼는 SID를 포함할 수 있을 만큼 커야 합니다. 버퍼가 너무 작으면 함수는 ERROR_MORE_DATA 반환하고 종료 NULL 문자를 포함하지 않고 *pcchSid SID의 TCHAR 수로 설정합니다.

szSid NULL 설정되고 pcchSid 유효한 포인터로 설정된 경우 함수는 ERROR_SUCCESS 반환하고 *pcchSid 종료 NULL포함하지 않고 값의 TCHAR 수로 설정합니다. 그런 다음 함수를 다시 호출하여 값을 검색할 수 있으며, szSid 버퍼는 *pcchSid + 1자를 포함할 수 있을 만큼 큽니다.

szSidpcchSid 모두 NULL설정되면 값을 검색하지 않고 값이 있는 경우 ERROR_SUCCESS 반환합니다.

[in, out, optional] pcchSid

함수를 호출할 때 이 매개 변수는 szSid 버퍼의 TCHAR 수를 지정하는 변수에 대한 포인터여야 합니다. 함수가 반환될 때 이 매개 변수는 함수가 지정된 버퍼에 값을 복사하는지 여부에 관계없이 요청된 값의 크기로 설정됩니다. 크기는 종료 null 문자를 포함하지 않고 요청된 값에서 TCHAR 수로 반환됩니다.

이 매개 변수는 szSid NULL경우에만 NULL 설정할 수 있습니다. 그렇지 않으면 함수는 ERROR_INVALID_PARAMETER 반환합니다.

반환 값

MsiEnumProductsEx 함수는 다음 값 중 하나를 반환합니다.

반환 코드 묘사
ERROR_ACCESS_DENIED
범위에 현재 사용자 이외의 사용자가 포함된 경우 관리자 권한이 필요합니다.
ERROR_BAD_CONFIGURATION
구성 데이터가 손상되었습니다.
ERROR_INVALID_PARAMETER
잘못된 매개 변수가 함수에 전달되었습니다.
ERROR_NO_MORE_ITEMS
열거할 제품이 더 이상 없습니다.
ERROR_SUCCESS
제품이 열거됩니다.
ERROR_MORE_DATA
szSid 매개 변수가 너무 작아서 사용자 SID를 가져올 수 없습니다.
ERROR_UNKNOWN_PRODUCT
지정된 컨텍스트의 컴퓨터에 제품이 설치되어 있지 않습니다.
ERROR_FUNCTION_FAILED
예기치 않은 내부 오류입니다.

발언

제품을 열거하려면 애플리케이션이 처음에 iIndex 매개 변수가 0으로 설정된 MsiEnumProductsEx 함수를 호출해야 합니다. 그런 다음 애플리케이션은 iProductIndex 매개 변수를 증가시키고 ERROR_NO_MORE_ITEMS 반환하고 열거할 제품이 더 이상 없을 때까지 MsiEnumProductsEx 호출해야 합니다.

모든 제품을 열거하기 위해 MsiEnumProductsEx 여러 번 호출하는 경우 각 호출은 동일한 스레드에서 수행되어야 합니다.

사용자는 모든 사용자 계정 또는 현재 사용자 계정 이외의 사용자 계정에서 제품을 열거할 수 있는 관리자 권한이 있어야 합니다. 열거형은 현재 사용자 이외의 모든 사용자 또는 사용자에 대해 열거할 때 사용자별 관리되지 않는 컨텍스트에서만 보급된 제품(예: 설치되지 않은 제품)을 건너뜁니다.

MsiGetProductInfoEx 사용하여 MsiEnumProductsEx열거된 각 제품 인스턴스에 대한 상태 또는 기타 정보를 가져옵니다.

메모

msi.h 헤더는 MSiEnumProductsEx를 유니코드 전처리기 상수의 정의에 따라 이 함수의 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 Server 2003 또는 Windows XP의 Windows Installer 3.0 이상 Windows Installer 버전에 필요한 최소 Windows 서비스 팩에 대한 자세한 내용은 Windows Installer Run-Time 요구 사항을 참조하세요.
대상 플랫폼 Windows
헤더 msi.h
라이브러리 Msi.lib
DLL Msi.dll

참고 항목

MsiEnumProducts

Windows Installer 2.0 및 이전 지원되지 않음

ProductCode

패치 제거