File: getnameinfo.3

package info (click to toggle)
manpages-ja 0.5.0.0.20100315-1
  • links: PTS
  • area: main
  • in suites: squeeze
  • size: 21,156 kB
  • ctags: 1
  • sloc: sh: 13,935; perl: 157; makefile: 114
file content (292 lines) | stat: -rw-r--r-- 7,908 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
.\" This page is in the public domain.
.\" Almost all details are from RFC 2553.
.\"
.\" 2004-12-14, mtk, Added EAI_OVERFLOW error
.\" 2004-12-14 Fixed description of error return
.\"
.\" Translated 2005-02-26, Akihiro MOTOKI <amotoki@dd.iij4u.or.jp>
.\" Updated 2007-01-07, Akihiro MOTOKI, LDP v2.43
.\" Updated 2008-08-11, Akihiro MOTOKI, LDP v3.05
.\"
.TH GETNAMEINFO 3 2009-02-23 "GNU" "Linux Programmer's Manual"
.SH ̾
getnameinfo \- ɥ쥹̾ؤѴץȥ˰¸ʤǹԤ
.SH 
.nf
.B #include <sys/socket.h>
.B #include <netdb.h>
.sp
.BI "int getnameinfo(const struct sockaddr *" "sa" ", socklen_t " "salen" ,
.BI "                char *" "host" ", size_t " "hostlen" ,
.BI "                char *" "serv" ", size_t " "servlen" ", int " "flags" );
.fi
.sp
.in -4n
glibc εǽޥ׷
.RB ( feature_test_macros (7)
):
.ad l
.in
.sp
.BR getnameinfo ():
_POSIX_C_SOURCE\ >=\ 1 || _XOPEN_SOURCE || _POSIX_SOURCE
.ad b
.SH 
.BR getnameinfo ()
ؿϡ
.BR getaddrinfo (3)
εդưԤĤޤꡢץȥ˰¸ʤ
åȥɥ쥹бۥ̾ȥӥؤѴԤ
δؿ
.BR gethostbyaddr (3)

.BR getservbyport (3)
εǽĤˤΤ
δؿȰ㤤
.BR getnameinfo (3)
ϥꥨȥȤǤꡢIPv4  IPv6 κʬ˰¸ʤ
ץ񤯤ȤǤ롣

.I sa
ϡ
IP ɥ쥹ȥݡֹξݻƤ
Ūʥåȥɥ쥹¤
.RI ( sockaddr_in
ޤ
.I sockaddr_in6
) ؤΥݥ󥿤Ǥ롣
.I salen

.I sa
ΥǤ롣
.I host

.I serv
ϡ(줾쥵
.I hostlen

.I servlen
) ƤӽФ¦dzݤ줿ХåեؤΥݥ󥿤Ǥꡢ
ۥ̾ȥӥ̾ޤ NULL ü줿ʸ
줾ΥХåե˳Ǽ롣

ۥ̾פǤ뤳Ȥ򤳤δؿˤϡ
.I host
 NULL ꤹ뤫
.I hostlen
 0 ꤹ롣Ʊͤˡӥ̾פʾϡ
.I serv
 NULL ꤹ뤫
.I servlen
 0 ꤹ롣
ۥ̾ȥӥ̾ξפȻꤹ뤳ȤϤǤʤ
(줫׵᤹뤳)

.I flags

.BR getnameinfo ()
ưѤ뤳ȤǤ롣Ǥͤϰʲ̤:
.TP
.B NI_NAMEREQD
ꤹȡۥ̾Ǥʤä˥顼֤
.TP
.B NI_DGRAM
ꤹȡȥ꡼١ (TCP) Ǥʤǡ١ (UDP)
Υӥоݤˤ롣Ͼʤ
UDP  TCP ǰ㤦ӥ󶡤Ƥݡ
(512-514) ФɬפȤʤ롣
.TP
.B NI_NOFQDN
ꤹȡʥۥȤˤ fully qualified domain name (FQDN) 
ۥ̾ʬΤߤ֤
.TP
.B NI_NUMERICHOST
ꤹȡͷΥۥ֤̾롣
.\" 㤨
.\" .BR gethostbyaddr ()
.\" 
.\" .BR inet_ntop ()
.\" Ƥ
(ꤷʤƤ⡢Ρɤ̾ǤʤϿͷ֤뤳Ȥ)
.\" POSIX.1-2003 has NI_NUMERICSCOPE, but glibc doesn't have it.
.TP
.B NI_NUMERICSERV
ꤹȡͷΥӥ̾ (㤨Хݡֹ) ֤
(ꤷʤƤ⡢ӥ̾ǤʤϿͷ֤뤳Ȥ)
.SS "ݲɥᥤ̾Τ getnameinfo() γĥ"
.PP
glibc 2.3.4 顢
.BR getnameinfo ()
˳ĥԤ졢ۥ̾
ݲɥᥤ̾ (Internationalized Domain Name; IDN) Ȥδ֤
ƩŪѴǤ褦ˤʤäƤ
(IDN ˤĤƤ RFC 3490 
.I "Internationalizing Domain Names in Applications (IDNA)"
򻲾)3ĤΥե饰Ƥ:
.TP
.B NI_IDN
Υե饰ꤹȡɬפǤСǸĤä̾
IDN ˱沽Ѵ롣
ASCII ʸ̾ϤѴǤϱƶʤΤᡢ
¸ΥץĶǤΥե饰ȤȤǤ롣
.TP
.BR NI_IDN_ALLOW_UNASSIGNED ", " NI_IDN_USE_STD3_ASCII_RULES
Υե饰򥻥åȤȡIDNA ǻѤե饰
IDNA_ALLOW_UNASSIGNED (̤Ƥ Unicode ΥɥݥȤ) 
IDNA_USE_STD3_ASCII_RULES (Ϥ STD3 Υۥ̾å)
줾ͭˤʤ롣
.SH ֤
.\" FIXME glibc defines the following additional errors, some which
.\" can probably be returned by getnameinfo(); they need to
.\" be documented.
.\" #ifdef __USE_GNU
.\" #define EAI_INPROGRESS  -100  /* Processing request in progress.  */
.\" #define EAI_CANCELED    -101  /* Request canceled.  */
.\" #define EAI_NOTCANCELED -102  /* Request not canceled.  */
.\" #define EAI_ALLDONE     -103  /* All requests done.  */
.\" #define EAI_INTR        -104  /* Interrupted by a signal.  */
.\" #define EAI_IDN_ENCODE  -105  /* IDN encoding failed.  */
.\" #endif
 0 ֤ꡢ(׵ᤵƤ) Ρɤȥӥ̾
NULL ü줿ʸηǤ줾λХåե֤
(ХåեĹˤ褦˽̤뤫⤷ʤ)
顼ξϡʲ 0 ʳΥ顼ɤ֤:
.TP
.B EAI_AGAIN
ꤵ줿̾ǤϲǤʤä
ǺƻԤƤߤ뤳ȡ
.TP
.B EAI_BADFLAGS
.I flags
ͤͿ줿
.TP
.B EAI_FAIL
Ǥʤ顼ȯ
.TP
.B EAI_FAMILY
ꤷɥ쥹եߥ꡼ǧǤʤä
뤤ϥɥ쥹Ĺꤵ줿եߥ꡼˹礦ΤǤʤä
.TP
.B EAI_MEMORY
꤬­ʤ
.TP
.B EAI_NONAME
Ϳ줿ѥ᡼Ǥ̾Ǥʤ
.B NI_NAMEREQD
ꤵƤۥ̾Ǥʤä
ۥ̾⥵ӥ̾׵ᤵʤä
.TP
.B EAI_OVERFLOW
.I host
ޤ
.I serv
ؤƤХåե
.TP
.B EAI_SYSTEM
ƥ२顼ä
顼ɤ
.I errno
ꤵ롣
.PP
.BR gai_strerror (3)
ؿȤȡΥ顼ɤ򡢥顼ݡȤŬ
ʹ֤ɤߤ䤹ʸƤ롣
.SH ե
/etc/hosts
.br
/etc/nsswitch.conf
.br
/etc/resolv.conf
.SH С
.BR getnameinfo ()
ϡglibc С 2.1 ʹߤ󶡤Ƥ롣
.SH 
RFC\ 2553, POSIX.1-2001.
.SH 
ŬڤʥХåեǤ褦ˡ
.I <netdb.h>
˰ʲƤ롣
.in +4n
.nf

#define NI_MAXHOST      1025
#define NI_MAXSERV      32
.fi
.in
.PP
ԤϡǶΥС BIND Υإåե
.I <arpa/nameser.h>

.B MAXDNAME
ƱͤǤ롣
ԤϡƺѤοͤˤĤƵߤ RFC 
󤵤ƥӥ̤ͤǤ롣
.SH 
ʲΥɤϡꤵ줿åȥɥ쥹Ф
ۥȤȥӥοɽ褦Ȼߤ롣
Υɥ쥹եߥ꡼Ф뻲Ⱦ
ڥϡɥɤƤʤȤܤƤۤ

.in +4n
.nf
struct sockaddr *sa;    /* input */
socklen_t len;          /* input */
char hbuf[NI_MAXHOST], sbuf[NI_MAXSERV];

if (getnameinfo(sa, len, hbuf, sizeof(hbuf), sbuf,
            sizeof(sbuf), NI_NUMERICHOST | NI_NUMERICSERV) == 0)
    printf("host=%s, serv=%s\en", hbuf, sbuf);
.fi
.in

ʲǤϥåȥɥ쥹
ոΥɥ쥹ޥåԥ󥰤¸ߤ뤫åƤ롣

.in +4n
.nf
struct sockaddr *sa;    /* input */
socklen_t len;          /* input */
char hbuf[NI_MAXHOST];

if (getnameinfo(sa, len, hbuf, sizeof(hbuf),
            NULL, 0, NI_NAMEREQD))
    printf("could not resolve hostname");
else
    printf("host=%s\en", hbuf);
.fi
.in
.PP
.BR getnameinfo ()
Ȥäץ㤬
.BR getaddrinfo (3)
˵ܤƤ롣
.SH Ϣ
.BR accept (2),
.BR getpeername (2),
.BR getsockname (2),
.BR recvfrom (2),
.BR socket (2),
.BR getaddrinfo (3),
.BR gethostbyaddr (3),
.BR getservbyname (3),
.BR getservbyport (3),
.BR inet_ntop (3),
.BR hosts (5),
.BR services (5),
.BR hostname (7),
.BR named (8)
.LP
R. Gilligan, S. Thomson, J. Bound and W. Stevens,
.IR "Basic Socket Interface Extensions for IPv6" ,
RFC\ 2553, March 1999.
.LP
Tatsuya Jinmei and Atsushi Onoe,
.IR "An Extension of Format for IPv6 Scoped Addresses" ,
internet draft, work in progress.
ftp://ftp.ietf.org/internet\-drafts/draft\-ietf\-ipngwg\-scopedaddr\-format\-02.txt
.LP
Craig Metz,
.IR "Protocol Independence Using the Sockets API" ,
Proceedings of the freenix track:
2000 USENIX annual technical conference, June 2000.
http://www.usenix.org/publications/library/proceedings/usenix2000/freenix/metzprotocol.html