SCardGetReaderDeviceInstanceIdW 함수(winscard.h)
SCardGetReaderDeviceInstanceId 함수는 지정된 판독기 이름에 대한 카드 판독기의 디바이스 인스턴스 식별자를 가져옵니다. 이 함수는 판독기의 상태에 영향을 주지 않습니다.
통사론
LONG SCardGetReaderDeviceInstanceIdW(
[in] SCARDCONTEXT hContext,
[in] LPCWSTR szReaderName,
[out, optional] LPWSTR szDeviceInstanceId,
[in, out] LPDWORD pcchDeviceInstanceId
);
매개 변수
[in] hContext
쿼리에 대한 리소스 관리자 컨텍스트를 식별하는 핸들입니다.
SCardEstablishContext 함수에 대한 이전 호출을 통해 리소스 관리자 컨텍스트를 설정할 수 있습니다. 이 매개 변수는 NULL
[in] szReaderName
판독기 이름입니다. SCardListReaders 함수를 호출하여 이 값을 가져올 수 있습니다.
[out, optional] szDeviceInstanceId
판독기의 디바이스 인스턴스 ID를 수신하는 버퍼입니다. 이 값이 NULL
[in, out] pcchDeviceInstanceId
NULL 종결자를 포함하여 szDeviceInstanceId 버퍼의 길이(문자)입니다. 버퍼 길이가 SCARD_AUTOALLOCATE 지정되면 szDeviceInstanceId 매개 변수가 바이트 포인터에 대한 포인터로 변환되고 인스턴스 ID가 포함된 메모리 블록의 주소를 받습니다. 이 메모리 블록은 SCardFreeMemory 함수로 할당을 취소해야 합니다.
반환 값
이 함수는 성공 여부에 따라 다른 값을 반환합니다.
반환 코드 | 묘사 |
---|---|
|
SCARD_S_SUCCESS. |
|
오류 코드입니다. 자세한 내용은 스마트 카드 반환 값 |
발언
이 함수는 리디렉션되지 않습니다. 원격 데스크톱 세션 내에서 SCARD_E_READER_UNAVAILABLE 오류 코드와 함께 실패할 때 SCardGetReaderDeviceInstanceId 함수를 호출합니다.
예제
LONG lReturn;
LPTSTR szReaderName = "USB Smart Card Reader 0";
WCHAR szDeviceInstanceId[256];
DWORD cchDeviceInstanceId = 256;
// Retrieve the reader's device instance ID.
// hContext was set by a previous call to SCardEstablishContext.
lReturn = SCardGetReaderDeviceInstanceId (hContext,
szReaderName,
szDeviceInstanceId,
&cchDeviceInstanceId);
if ( SCARD_S_SUCCESS != lReturn )
{
printf("Failed SCardGetReaderDeviceInstanceId - %x\n", lReturn);
// Take appropriate action.
}
메모
winscard.h 헤더는 유니코드 전처리기 상수의 정의에 따라 이 함수의 ANSI 또는 유니코드 버전을 자동으로 선택하는 별칭으로 SCardGetReaderDeviceInstanceId를 정의합니다. 인코딩 중립 별칭을 인코딩 중립이 아닌 코드와 혼합하면 컴파일 또는 런타임 오류가 발생하는 불일치가 발생할 수 있습니다. 자세한 내용은 함수 프로토타입대한
요구 사항
요구 | 값 |
---|---|
지원되는 최소 클라이언트 | Windows 8 [데스크톱 앱만 해당] |
지원되는 최소 서버 | Windows Server 2012 [데스크톱 앱만 해당] |
대상 플랫폼 | Windows |
헤더 | winscard.h |