Функция GetAddressByNameW (nspapi.h)
[GetAddressByName больше недоступен для использования в windows Sockets 2. Вместо этого используйте функции, подробные в Protocol-Independent разрешения имен.]
Функция GetAddressByName запрашивает пространство имен или набор пространств имен по умолчанию, чтобы получить сведения о сетевом адресе для указанной сетевой службы. Этот процесс называется разрешением имен службы. Сетевая служба также может использовать функцию для получения сведений о локальном адресе, которые он может использовать с функцией привязки.
Синтаксис
INT GetAddressByNameW(
[in] DWORD dwNameSpace,
[in] LPGUID lpServiceType,
[in, optional] LPWSTR lpServiceName,
[in, optional] LPINT lpiProtocols,
[in] DWORD dwResolution,
[in, optional] LPSERVICE_ASYNC_INFO lpServiceAsyncInfo,
[out] LPVOID lpCsaddrBuffer,
[in, out] LPDWORD lpdwBufferLength,
[in, out] LPWSTR lpAliasBuffer,
[in, out] LPDWORD lpdwAliasBufferLength
);
Параметры
[in] dwNameSpace
Пространство имен или набор пространств имен по умолчанию, которые операционная система должна запрашивать сведения о сетевом адресе.
Используйте одну из следующих констант, чтобы указать пространство имен.
Большинство вызовов GetAddressByName должны использовать специальное значение NS_DEFAULT. Это позволяет клиенту получать данные без знаний о том, какие пространства имен доступны в Интернете. Системный администратор определяет доступ к пространству имен. Пространства имен могут поступать и идти без необходимости знать об изменениях.
[in] lpServiceType
Указатель на глобальный уникальный идентификатор (GUID), указывающий тип сетевой службы. Файл заголовка Svcguid.h включает определения нескольких типов служб GUID и макросы для работы с ними.
Файл заголовка Svcguid.h не включается в файл заголовка Winsock2.h автоматически.
[in, optional] lpServiceName
Указатель на строку, которая однозначно представляет имя службы. Например, "MY SNA SERVER".
Параметр lpServiceNameNULL эквивалентен параметру dwResolution значение RES_SERVICE. Функция работает во втором режиме, получая локальный адрес, к которому должна привязаться служба указанного типа. Функция сохраняет локальный адрес в localAddr член структуры CSADDR_INFO, хранящихся в *lpCsaddrBuffer.
Если dwResolution задано значение RES_SERVICE, функция игнорирует параметр lpServiceName.
Если dwNameSpace задано значение NS_DNS, *lpServiceName — это имя узла.
[in, optional] lpiProtocols
Указатель на неоканированный массив идентификаторов протокола. Функция ограничивает разрешение имен поставщиками пространств имен, которые предлагают эти протоколы. Это позволяет вызывающему объекту ограничить область поиска.
Если lpiProtocols задано значение NULL, функция получает сведения обо всех доступных протоколах.
[in] dwResolution
Набор битовых флагов, указывающих аспекты процесса разрешения имен службы. Определены следующие битовые флаги.
[in, optional] lpServiceAsyncInfo
Зарезервировано для дальнейшего использования; необходимо задать значение NULL.
[out] lpCsaddrBuffer
Указатель на буфер для получения одной или нескольких CSADDR_INFO структур данных. Количество структур, записанных в буфер, зависит от объема информации, найденной в попытке разрешения. Следует предположить, что несколько структур будут написаны, хотя во многих случаях будет только одна.
[in, out] lpdwBufferLength
Указатель на переменную, указывающую размер буфера в байтах, на который указывает lpCsaddrBuffer.
При выходе эта переменная содержит общее количество байтов, необходимых для хранения массива CSADDR_INFO структур. Если это значение меньше или равно входным значениям *lpdwBufferLength, а функция выполнена успешно, это число байтов, хранящихся в буфере. Если это значение больше входного значения *lpdwBufferLength, буфер был слишком мал, а выходное значение *lpdwBufferLength является минимальным обязательным размером буфера.
[in, out] lpAliasBuffer
Указатель на буфер для получения сведений псевдонима для сетевой службы.
Если пространство имен поддерживает псевдонимы, функция сохраняет массив строк имен без нуля в буфер, на который указывает lpAliasBuffer. В конце списка имеется двойной ноль-терминатор. Первое имя в массиве — это основное имя службы. Следующие имена являются псевдонимами. Пример пространства имен, поддерживающего псевдонимы, — DNS.
Если пространство имен не поддерживает псевдонимы, он сохраняет двойной ноль-терминатор в буфер.
Этот параметр является необязательным и может иметь значение NULL.
[in, out] lpdwAliasBufferLength
Указатель на переменную, которая при входе указывает размер в элементах (символах), на который указывает lpAliasBuffer.
При выходных данных эта переменная содержит общее количество элементов (символов), необходимых для хранения массива строк имен. Если это значение меньше или равно входным значениям *lpdwAliasBufferLength, а функция выполнена успешно, это число элементов, хранящихся в буфере. Если это значение больше входного значения *lpdwAliasBufferLength, буфер был слишком мал, а выходное значение *lpdwAliasBufferLength является минимальным обязательным размером буфера.
Если lpAliasBufferNULL, lpdwAliasBufferLength бессмысленно, а также может быть NULL.
Возвращаемое значение
Если функция выполнена успешно, возвращаемое значение — это число структур данных CSADDR_INFO, записанных в буфер, на который указывает lpCsaddrBuffer.
Если функция завершается ошибкой, возвращаемое значение равно SOCKET_ERROR( –1). Чтобы получить расширенные сведения об ошибке, вызовите GetLastError, которое возвращает следующее расширенное значение ошибки.
Код ошибки | Значение |
---|---|
|
Буфер, на который указывает lpCsaddrBuffer, слишком мал, чтобы получить все соответствующие структуры CSADDR_INFO. Вызовите функцию с буфером по крайней мере размером, как значение, возвращаемое в *lpdwBufferLength. |
Замечания
Эта функция является более мощной версией функции gethostbyname. Функция GetAddressByName
Функция GetAddressByName
Многие службы имен поддерживают префикс или суффикс по умолчанию, который поставщик служб имен учитывает при разрешении имен служб. Например, в пространстве имен DNS, если домен называется "nt.microsoft.com", а "ftp милликан" предоставляется в качестве входных данных, программное обеспечение DNS не удается разрешить "милликан", но успешно разрешает "millikan.nt.microsoft.com".
Обратите внимание, что функция GetAddressByName может выполнять поиск адреса службы двумя способами: в пределах определенного пространства имен или в наборе пространств имен по умолчанию. Используя пространство имен по умолчанию, администратор может указать, что определенные пространства имен будут искать адреса службы только в том случае, если указано по имени. Администратор или пространство имен— программа установки также может управлять порядком поиска пространства имен.
Заметка
Заголовок nspapi.h определяет GetAddressByName как псевдоним, который автоматически выбирает версию ANSI или Юникод этой функции на основе определения константы препроцессора ЮНИКОДа. Сочетание использования псевдонима, нейтрального для кодирования, с кодом, не зависящим от кодирования, может привести к несоответствиям, которые приводят к ошибкам компиляции или среды выполнения. Дополнительные сведения см. в соглашениях о прототипах функций.
Требования
Требование | Ценность |
---|---|
минимальные поддерживаемые клиентские | Windows 2000 Профессиональный [только классические приложения] |
минимальный поддерживаемый сервер | Windows 2000 Server [только классические приложения] |
целевая платформа | Виндоус |
заголовка | nspapi.h |
библиотеки |
Mswsock.lib |
DLL | Mswsock.dll |
См. также
Справочник