Поделиться через


структура ADDRINFOEX5 (ws2def.h)

Структура addrinfoex4 используется функцией GetAddrInfoEx для хранения сведений об адресе узла при запросе определенного сетевого интерфейса.

Синтаксис

typedef struct addrinfoex5 {
  int                ai_flags;
  int                ai_family;
  int                ai_socktype;
  int                ai_protocol;
  size_t             ai_addrlen;
  PWSTR              ai_canonname;
  struct sockaddr    *ai_addr;
  void               *ai_blob;
  size_t             ai_bloblen;
  GUID               *ai_provider;
  struct addrinfoex5 *ai_next;
  int                ai_version;
  PWSTR              ai_fqdn;
  int                ai_interfaceindex;
  HANDLE             ai_resolutionhandle;
  unsigned int       ai_ttl;
} ADDRINFOEX5, *PADDRINFOEX5, *LPADDRINFOEX5;

Члены

ai_flags

Флаги, указывающие параметры, используемые в функции GetAddrInfoEx .

Поддерживаемые значения для элемента ai_flags определяются в файле Winsock2.h include и могут быть комбинацией следующих параметров.

Значение Значение
AI_PASSIVE
0x01
Адрес сокета будет использоваться при вызове функции bind.
AI_CANONNAME
0x02
Каноническое имя возвращается в первом элементе ai_canonname .
AI_NUMERICHOST
0x04
Параметр nodename , передаваемый в функцию GetAddrInfoEx , должен быть числовой строкой.
AI_ALL
0x0100
Если этот бит задан, выполняется запрос на адреса IPv6 и IPv4 с AI_V4MAPPED.

Этот параметр поддерживается в Windows Vista и более поздних версиях.

AI_ADDRCONFIG
0x0400
GetAddrInfoEx будет разрешаться, только если настроен глобальный адрес. Адрес замыкания на себя IPv6 и IPv4 не считается допустимым глобальным адресом.

Этот параметр поддерживается в Windows Vista и более поздних версиях.

AI_V4MAPPED
0x0800
Если запрос GetAddrInfoEx для IPv6-адресов завершается сбоем, выполняется запрос службы имен для IPv4-адресов, и эти адреса преобразуются в формат IPv4-адресов.

Этот параметр поддерживается в Windows Vista и более поздних версиях.

AI_NON_AUTHORITATIVE
0x04000
Адресная информация получена из результатов, не заслуживающих доверия.

Если этот параметр задан в параметре pHintsgetAddrInfoEx, поставщик пространства имен NS_EMAIL возвращает как заслуживающие доверия, так и неавторитетные результаты. Если этот параметр не задан, возвращаются только достоверные результаты.

Этот параметр поддерживается только в Windows Vista и более поздних версиях для пространства имен NS_EMAIL .

AI_SECURE
0x08000
Сведения об адресе передаются из защищенного канала.

Если задан бит AI_SECURE , поставщик пространства имен NS_EMAIL вернет результаты, полученные с повышенной безопасностью, чтобы свести к минимуму возможные спуфинговы.

Если этот параметр задан в параметре pHintsgetAddrInfoEx, поставщик пространства имен NS_EMAIL возвращает только результаты, полученные с повышенной безопасностью, чтобы свести к минимуму возможный спуфинг.

Этот параметр поддерживается только в Windows Vista и более поздних версиях для пространства имен NS_EMAIL .

AI_RETURN_PREFERRED_NAMES
0x010000
Сведения об адресе относятся к предпочтительному имени публикации с определенным пространством имен.

Если этот параметр задан в параметре pHintsgetAddrInfoEx, в параметре pName не должно быть указано имя, а поставщик пространства имен NS_EMAIL вернет предпочтительные имена для публикации.

Этот параметр поддерживается только в Windows Vista и более поздних версиях для пространства имен NS_EMAIL .

AI_FQDN
0x00020000
Полное доменное имя возвращается в первом элементе ai_fqdn .

Если этот параметр задан в параметре pHintsgetAddrInfoEx и в параметре pName указано неструктурированное имя (одна метка), возвращается полное доменное имя, в которое в конечном итоге разрешается имя.

Этот параметр поддерживается в Windows 7, Windows Server 2008 R2 и более поздних версиях.

AI_FILESERVER
0x00040000
Указание поставщику пространства имен о том, что запрашиваемое имя узла используется в сценарии общей папки. Поставщик пространства имен может игнорировать это указание.

Этот параметр поддерживается в Windows 7, Windows Server 2008 R2 и более поздних версиях.

AI_DISABLE_IDN_ENCODING
0x00080000
Отключите автоматическое кодирование международного доменного имени с помощью Punycode в функциях разрешения имен, вызываемых функцией GetAddrInfoEx .

Этот параметр поддерживается в Windows 8, Windows Server 2012 и более поздних версиях.

AI_EXTENDED
0x80000000
Указывает, что текущий объект расширен: addrinfoex2 или более поздней версии.

Этот параметр поддерживается в Windows 8.1, Windows Server 2012 R2 и более поздних версий.

AI_RESOLUTION_HANDLE
0x40000000
Дескриптор разрешения возвращается в элементе ai_resolutionhandle .

Этот параметр поддерживается в Windows 10, Windows Server 2016 и более поздних версиях.

AI_RETURN_TTL
0x0080
Количество секунд, в течение которых запись DNS действительна. Если этот флаг присутствует, getAddrInfoEx. Параметр ppResult возвращает список структур addrinfoex5 , где элемент ai_ttl будет содержать отдельный срок жизни записи DNS.

ai_family

Семейство адресов.

Возможные значения для семейства адресов определяются в файле заголовка Ws2def.h . Обратите внимание, что файл заголовка Ws2def.h автоматически включается в Winsock2.h и никогда не должен использоваться напрямую.

В настоящее время поддерживаются значения AF_INET или AF_INET6, которые являются форматами семейства адресов Интернета для IPv4 и IPv6. Другие параметры семейства адресов (например, AF_NETBIOS для использования с NetBIOS) поддерживаются, если установлен поставщик служб Windows Sockets для семейства адресов. Обратите внимание, что значения для семейства адресов AF_ и констант семейства протоколов PF_ идентичны (например, AF_INET и PF_INET), поэтому можно использовать любой из констант.

В таблице ниже перечислены распространенные значения для семейства адресов, хотя возможны и многие другие значения.

Значение Значение
AF_UNSPEC
0
Семейство адресов не указано.
AF_INET
2
Семейство адресов IPv4.
AF_NETBIOS
17
Семейство адресов NetBIOS. Это семейство адресов поддерживается только в том случае, если установлен поставщик Сокетов Windows для NetBIOS.
AF_INET6
23
Семейство адресов IPv6.
AF_IRDA
26
Семейство адресов Ассоциации инфракрасных данных (IrDA). Это семейство адресов поддерживается только в том случае, если на компьютере установлены инфракрасный порт и драйвер.
AF_BTH
32
Семейство адресов Bluetooth. Это семейство адресов поддерживается только в том случае, если установлен адаптер Bluetooth.

ai_socktype

Тип сокета. Возможные значения для типа сокета определяются во включаемом файле Winsock2.h .

В следующей таблице перечислены возможные значения для типа сокета, поддерживаемого для Windows Sockets 2:

Значение Значение
SOCK_STREAM
1
Предоставляет виртуационные, надежные двусторонние потоки байтов на основе подключений с механизмом передачи данных OOB. Использует протокол TCP для семейства адресов Интернета (AF_INET или AF_INET6). Если элемент ai_family является AF_IRDA, то единственным поддерживаемым типом сокета является SOCK_STREAM .
SOCK_DGRAM
2
Поддерживает датаграммы, которые представляют собой ненадежные буферы без подключения фиксированной (обычно небольшой) максимальной длины. Использует протокол UDP для семейства интернет-адресов (AF_INET или AF_INET6).
SOCK_RAW
3
Предоставляет необработанный сокет, который позволяет приложению управлять следующим заголовком протокола верхнего уровня. Чтобы управлять заголовком IPv4, для сокета необходимо задать параметр сокета IP_HDRINCL . Чтобы управлять заголовком IPv6, для сокета необходимо задать параметр сокета IPV6_HDRINCL .
SOCK_RDM
4
Предоставляет надежную датаграмму сообщения. Примером этого типа является реализация протокола прагматической общей многоадресной рассылки (PGM) в Windows, которую часто называют надежным многоадресным программированием.
SOCK_SEQPACKET
5
Предоставляет пакет псевдопотока на основе датаграмм.
 

В Windows Sockets 2 появились новые типы сокетов. Приложение может динамически обнаруживать атрибуты каждого доступного транспортного протокола с помощью функции WSAEnumProtocols . Поэтому приложение может определить возможный тип сокета и параметры протокола для семейства адресов и использовать эти сведения при указании этого параметра. Определения типов сокетов в файлах заголовков Winsock2.h и Ws2def.h будут периодически обновляться по мере определения новых типов сокетов, семейств адресов и протоколов.

В Windows Sockets 1.1 единственными возможными типами сокетов являются SOCK_DATAGRAM и SOCK_STREAM.

ai_protocol

Тип протокола. Возможные параметры относятся к указанному семейству адресов и типу сокета. Возможные значения для ai_protocol определяются в файлах заголовков Winsock2.h и Wsrm.h .

В windows SDK, выпущенном для Windows Vista и более поздних версий, организация файлов заголовков изменилась, и этот элемент может быть одним из значений из типа перечисления IPPROTO , определенного в файле заголовка Ws2def.h . Обратите внимание, что файл заголовка Ws2def.h автоматически включается в Winsock2.h и никогда не должен использоваться напрямую.

Если для ai_protocol задано значение 0, вызывающий объект не хочет указывать протокол, и поставщик услуг выберет ai_protocol для использования. Для протоколов, отличных от IPv4 и IPv6, задайте для ai_protocol нулевое значение.

В следующей таблице перечислены общие значения для элемента ai_protocol , хотя возможны и многие другие значения.

Значение Значение
IPPROTO_TCP
6
Протокол TCP. Это возможное значение, если элемент ai_familyявляется AF_INET или AF_INET6 , а элемент ai_socktype— SOCK_STREAM.
IPPROTO_UDP
17
Протокол пользовательских датаграмм (UDP). Это возможное значение, если элемент ai_familyAF_INET или AF_INET6 , а параметр typeSOCK_DGRAM.
IPPROTO_RM
113
Протокол PGM для надежной многоадресной рассылки. Это возможное значение, если элемент ai_familyAF_INET , а элемент ai_socktypeSOCK_RDM. В windows SDK, выпущенном для Windows Vista и более поздних версий, это значение также называется IPPROTO_PGM.
 

Если элемент ai_familyявляется AF_IRDA, то ai_protocol должен иметь значение 0.

ai_addrlen

Длина (в байтах) буфера, на который указывает элемент ai_addr .

ai_canonname

Каноническое имя узла.

ai_addr

Указатель на структуру sockaddr . Элемент ai_addr в каждой возвращенной структуре addrinfoex4 указывает на заполненную структуру адресов сокета. Длина каждой возвращаемой структуры addrinfoex4 в байтах указывается в элементе ai_addrlen .

ai_blob

Указатель на данные, используемые для возврата сведений о пространстве имен конкретного поставщика, связанных с именем за пределами списка адресов. Длина буфера, на который указывает ai_blob , в байтах должна быть указана в элементе ai_bloblen .

ai_bloblen

Длина элемента ai_blob в байтах.

ai_provider

Указатель на GUID определенного поставщика пространства имен.

ai_next

Указатель на следующую структуру в связанном списке. Этот параметр имеет значение NULL в последней структуре addrinfoex4 связанного списка.

ai_version

Номер версии этой структуры. В настоящее время для этой версии структуры используется значение 4.

ai_fqdn

Полное доменное имя узла.

ai_interfaceindex

Индекс интерфейса, определенный в IP_ADAPTER_ADDRESSES. Свойство IfIndex , возвращаемое в GetAdaptersAddresses.

ai_resolutionhandle

Дескриптор, указывающий на полное доменное имя узла.

ai_ttl

Количество секунд, в течение которых эта запись DNS действительна.

Комментарии

Структура ADDRINFOEX5 используется функцией GetAddrInfoExW для хранения сведений об адресе узла, если AI_EXTENDED или AI_RETURN_TTL биты заданы в элементе ai_flags, передаваемом через параметр указанийGetAddrInfoExW.

Структура ADDRINFOEX5 является расширением структуры ADDRINFOEX4 . Помимо всех полей из структуры ADDRINFOEX4 , он также содержит в элементе ai_ttl отдельный срок жизни DNS для каждого возвращаемого IP-адреса.

Если бит AI_RETURN_TTL задан в элементе ai_flags, передаваемом с помощью параметра GetAddrInfoExExhints, параметр PpResultGetAddrInfoExW вернет список ADDRINFOEX5 структур. Каждый узел в этом списке будет содержать в элементе ai_ttl отдельный срок жизни DNS для IP-адреса, присутствующего в элементе sockaddr .

Примеры

См. пример кода в разделе структура ADDRINFOEX4 .

Требования

   
Минимальная версия клиента Сборка Windows 10 20348
Минимальная версия сервера Сборка Windows 10 20348
Верхняя часть ws2def.h

См. также раздел

GetAddrInfoEx

addrinfo

addrinfoW

addrinfoex

addrinfoex3