> Linux Reviews > man >

inet


  1. inet.3.man


1. inet.3.man

Manpage of INET

INET

Section: Руководство программиста Linux (3)
Updated: 2008-06-19
Index Return to Main Contents
 

ИМЯ

inet_aton, inet_addr, inet_network, inet_ntoa, inet_makeaddr, inet_lnaof, inet_netof - функции для работы с адресами Интернет  

ОБЗОР

#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>

int inet_aton(const char *cp, struct in_addr *inp);

in_addr_t inet_addr(const char *cp);

in_addr_t inet_network(const char *cp);

char *inet_ntoa(struct in_addr in);

struct in_addr inet_makeaddr(int net, int host);

in_addr_t inet_lnaof(struct in_addr in);

in_addr_t inet_netof(struct in_addr in);

Требования макроса тестирования свойств для glibc (см. feature_test_macros(7)):

inet_aton(), inet_ntoa(): _BSD_SOURCE || _SVID_SOURCE  

ОПИСАНИЕ

inet_aton() преобразует адрес Интернет-узла cp из числовой формы записи IPv4 с точками (IPv4 numbers-and-dots) в двоичную форму (с сетевым порядком байт) и сохраняет её в структуре, на которую ссылается inp. inet_aton() возвращает ненулевое значение, если адрес правильный, и ноль, если нет. Адрес, указанный в cp, может принимать одну из следующих форм:
a.b.c.d
Каждая из четырёх групп чисел представляет байт адреса; байты назначаются слева направо.
a.b.c
Части a и b задают первые два байта двоичного адреса. Часть c расценивается как 16-разрядное значение, определяющее два самых правых байта двоичного адреса. Такая запись совместима c сетевыми адресами (устаревшими) класса B.
a.b
Часть a определяет первый байт двоичного адреса. Часть b расценивается как 24-разрядное значение, определяющее три самых правых байта двоичного адреса. Данная форма записи совместима с сетевыми адресами (устаревшими) класса C.
a
Значение a расценивается как 32-разрядное значение, которое хранится в двоичном формате без какой либо перегруппировки байтов.

Во всех вышеперечисленные формах записи адресов числа могут быть указаны в десятичной, восьмеричной (с префиксом 0) или шестнадцатеричной (с префиксом 0X) системе счисления. Адреса, записанные в любой из этих форм, называются числовой формой записи IPv4 с точками. Форма записи, в которой используются только четыре десятичных числа, называется десятично-точечной записью IPv4 (IPv4 dotted-decimal notation) или иногда IPv4 dotted-quad notation.

Функция inet_addr() преобразует адрес Интернет-узла cp из числовой формы записи IPv4 с точками в двоичную форму с сетевым порядком байт. Если адрес, подаваемый на вход, неверный, функция возвращает INADDR_NONE (обычно -1). Использование этой функции проблематично, т.к. значение -1 эквивалентно корректному адресу (255.255.255.255). Избегайте использования этой функции, вместо нее используйте inet_aton(), inet_pton(3) или getaddrinfo(3), которые предоставляют более правильный способ указания на ошибку.

Функция inet_network() преобразует строку cp, записанную в числовой форме записи IPv4 с точками, в число (порядок байт узла), пригодное для использования в качестве сетевого адреса интернета. В случае успешного выполнения возвращается преобразованный адрес. В случае указания некорректной строки, возвращается -1.

Функция inet_ntoa() преобразует адрес Интернет-узла in, заданного в сетевом порядке байтов, в строку в числовой форме записи IPv4 с точками. Строка возвращается в статически выделяемом буфере, который перезаписывается при последующих вызовах.

Функция inet_lnaof() возвращает номер узла из интернет-адреса in. Возвращаемое значение имеет порядок байт узла.

Функция inet_netof() возвращает номер сети из интернет-адреса in. Возвращаемое значение имеет порядок байт узла.

Функция inet_makeaddr() противоположна inet_netof() и inet_lnaof(). Она возвращает адрес Интернет-узла в сетевом порядке байт, создавая его путём объединения номера сети net с номером узла host (оба задаются в порядке байт узла).

Структура in_addr, используемая в inet_ntoa(), inet_makeaddr(), inet_lnaof() и inet_netof(), определена в <netinet/in.h>:

typedef uint32_t in_addr_t;

struct in_addr {
    in_addr_t s_addr;
};
 

СООТВЕТСТВИЕ СТАНДАРТАМ

4.3BSD. inet_addr() и inet_ntoa() определены в POSIX.1-2001. inet_aton() не определена в POSIX.1-2001, однако доступна на большинстве систем.  

ЗАМЕЧАНИЯ

На платформах i386 порядок байтов узла таков, что младший байт является первым (little endian = от младшего к старшему), а в сетевом порядке байт, который используется в интернет, старший байт является первым (big endian = от старшего к младшему).

inet_lnaof(), inet_netof() и inet_makeaddr() является устаревшими функциями, которые предполагают, что используется классовая сетевая адресация. При классовой адресации сетевой адрес IPv4 разделяется на узловой и сетевой компоненты по байтовой границе следующим образом:

Класс A
На данный тип адреса указывает 0 на месте старшего бита (сетевой порядок байтов) адреса. Сетевой адрес содержится в самом старшем байте, а адреса узлов занимают оставшиеся три байта.
Класс B
На данный тип адреса указывает двоичное значение 10 на месте двух самых старших битов (сетевой порядок байтов) адреса. Сетевой адрес содержится в двух старших байтах, а адреса узлов занимают оставшиеся два байта.
Класс C
На данный тип адреса указывает двоичное значение 110 на месте самых трех старших битов (сетевой порядок байтов) адреса. Сетевой адрес содержится в первых трёх старших байтах, а адреса узлов занимают оставшийся байт.

Классовая адресация в настоящее время устарела и была заменена на бесклассовую адресацию (CIDR), при которой компоненты сети и узла в адресе могут занимать произвольное число битов (а не байтов).  

ПРИМЕР

Ниже приведён код примера использования inet_aton() и inet_ntoa(). Рассмотрим результат работы примера:

$ ./a.out 226.000.000.037      # Последний байт в восьмеричной сс
226.0.0.31
$ ./a.out 0x7f.1               # Первый байт в шестнадцатеричной сс
127.0.0.1
 

Исходный код программы

#define _BSD_SOURCE
#include <arpa/inet.h>
#include <stdio.h>
#include <stdlib.h>

int
main(int argc, char *argv[])
{
    struct in_addr addr;

    if (argc != 2) {
        fprintf(stderr, "%s <dotted-address>
", argv[0]); exit(EXIT_FAILURE); } if (inet_aton(argv[1], &addr) == 0) { perror("inet_aton"); exit(EXIT_FAILURE); } printf("%s
", inet_ntoa(addr)); exit(EXIT_SUCCESS); }
 

СМОТРИТЕ ТАКЖЕ

byteorder(3), getaddrinfo(3), gethostbyname(3), getnameinfo(3), getnetent(3), inet_ntop(3), inet_pton(3), hosts(5), networks(5)


 

Index

ИМЯ
ОБЗОР
ОПИСАНИЕ
СООТВЕТСТВИЕ СТАНДАРТАМ
ЗАМЕЧАНИЯ
ПРИМЕР
Исходный код программы
СМОТРИТЕ ТАКЖЕ

This document was created by man2html using the manual pages.
Time: 17:41:21 GMT, October 23, 2013

SVENSKA - cs - SVENSKA - SVENSKA - ja