структура OPENCARD_SEARCH_CRITERIAW (winscard.h)
Структура OPENCARD_SEARCH_CRITERIA используется функцией SCardUIDlgSelectCard для распознавания карточек, которые соответствуют требованиям, заданным вызывающим оператором. Однако можно вызвать SCardUIDlgSelectCard без использования этой структуры.
Синтаксис
typedef struct {
DWORD dwStructSize;
LPWSTR lpstrGroupNames;
DWORD nMaxGroupNames;
LPCGUID rgguidInterfaces;
DWORD cguidInterfaces;
LPWSTR lpstrCardNames;
DWORD nMaxCardNames;
LPOCNCHKPROC lpfnCheck;
LPOCNCONNPROCW lpfnConnect;
LPOCNDSCPROC lpfnDisconnect;
LPVOID pvUserData;
DWORD dwShareMode;
DWORD dwPreferredProtocols;
} OPENCARD_SEARCH_CRITERIAW, *POPENCARD_SEARCH_CRITERIAW, *LPOPENCARD_SEARCH_CRITERIAW;
Члены
dwStructSize
Длина структуры в байтах. Не должно быть значение NULL.
lpstrGroupNames
Указатель на буфер, содержащий строки имени группы, завершающиеся значением NULL. Последняя строка в буфере должна быть завершена двумя пустыми символами. Каждая строка — это имя группы карточек, которая должна быть включена в поиск. Если lpstrGroupNamesNULL, выполняется поиск группы по умолчанию (Scard$DefaultReaders).
nMaxGroupNames
Максимальное количество байтов (версия ANSI) или символов (версия Юникода) в строке lpstrGroupNames.
rgguidInterfaces
Зарезервировано для дальнейшего использования. Массив идентификаторов GUID, определяющих необходимые интерфейсы. Установите для этого элемента значение NULL.
cguidInterfaces
Зарезервировано для дальнейшего использования. Количество интерфейсов в массиве rgguidInterfaces. Установите для этого элемента значение NULL.
lpstrCardNames
Указатель на буфер, содержащий строки имени карточки, завершаемой значением NULL. Последняя строка в буфере должна быть завершена двумя пустыми символами. Каждая строка — это имя карточки, которая должна находиться.
nMaxCardNames
Максимальное количество байтов (версия ANSI) или символов (версия Юникода) в строке lpstrGroupNames.
lpfnCheck
Указатель на процедуру проверки карточки вызывающего абонента. Если специальная проверка карты не требуется, этот указатель null. Если карточка отклоняется подпрограммой проверки, возвращается false, а карточка будет отключена. Если карточка принимается подпрограммой проверки, возвращается TRUE.
Прототип подпрограммы проверки выглядит следующим образом.
Boolean Check(
hSCardContext, // the card context passed in the parameter block
hCard, // card handle
pvUserData // pointer to user data passed in the parameter block
);
lpfnConnect
Указатель на подпрограмму подключения карточки вызывающего абонента. Если вызывающему объекту требуется выполнить дополнительную обработку для подключения к карточке, этот указатель функции устанавливается в функцию подключения пользователя. Если функция подключения выполнена успешно, карточка остается подключенной и инициализируется, а дескриптор карточки возвращается.
Прототип подпрограммы подключения выглядит следующим образом.
Connect(
hSCardContext, // the card context passed in the parameter block
szReader, // the name of the reader
mszCards, // multiple string that contains
// the possible card names in the reader
pvUserData // pointer to user data passed in parameter block
);
lpfnDisconnect
Указатель на подпрограмму отключения карточки вызывающего абонента.
Прототип подпрограммы отключения выглядит следующим образом.
Disconnect(
hSCardContext, // the card context passed in the parameter block
hCard, // card handle
pvUserData // pointer to user data passed in the parameter block
);
pvUserData
Указатель void на пользовательские данные. Этот указатель передается вызывающей стороне в подпрограммах подключения, проверки и отключения.
dwShareMode
Если lpfnConnect не null, dwShareMode и dwPreferredProtocols члены игнорируются. Если lpfnConnectNULL и dwShareMode ненулевое, внутренний вызов выполняется для SCardConnect, использующего dwShareMode и dwPreferredProtocols в качестве параметра.
dwPreferredProtocols
Используется для внутреннего подключения, как описано в dwShareMode.
Замечания
Заметка
Заголовок winscard.h определяет OPENCARD_SEARCH_CRITERIA как псевдоним, который автоматически выбирает версию ANSI или Юникод этой функции на основе определения константы препроцессора ЮНИКОДа. Сочетание использования псевдонима, нейтрального для кодирования, с кодом, не зависящим от кодирования, может привести к несоответствиям, которые приводят к ошибкам компиляции или среды выполнения. Дополнительные сведения см. в соглашениях о прототипах функций.
Требования
Требование | Ценность |
---|---|
минимальные поддерживаемые клиентские | Windows XP [только классические приложения] |
минимальный поддерживаемый сервер | Windows Server 2003 [только классические приложения] |
заголовка | winscard.h |