socket_getsockname
(PHP 4 >= 4.1.0, PHP 5)
socket_getsockname — Queries the local side of the given socket which may either result in host/port or in a Unix filesystem path, dependent on its type
Description
$socket
, string &$addr
[, int &$port
] )Note: socket_getsockname() should not be used with
AF_UNIX
sockets created with socket_connect(). Only sockets created with socket_accept() or a primary server socket following a call to socket_bind() will return meaningful values.
Parameters
-
socket
-
A valid socket resource created with socket_create() or socket_accept().
-
addr
-
If the given socket is of type
AF_INET
orAF_INET6
, socket_getsockname() will return the local IP address in appropriate notation (e.g. 127.0.0.1 or fe80::1) in theaddress
parameter and, if the optionalport
parameter is present, also the associated port.If the given socket is of type
AF_UNIX
, socket_getsockname() will return the Unix filesystem path (e.g. /var/run/daemon.sock) in theaddress
parameter. -
port
-
If provided, this will hold the associated port.
Return Values
Returns TRUE
on success or FALSE
on failure. socket_getsockname() may also return
FALSE
if the socket type is not any of AF_INET
,
AF_INET6
, or AF_UNIX
, in which
case the last socket error code is not updated.
See Also
- socket_getpeername() - Queries the remote side of the given socket which may either result in host/port or in a Unix filesystem path, dependent on its type
- socket_last_error() - Returns the last error on the socket
- socket_strerror() - Return a string describing a socket error
- socket_accept
- socket_bind
- socket_clear_error
- socket_close
- socket_cmsg_space
- socket_connect
- socket_create_listen
- socket_create_pair
- socket_create
- socket_get_option
- socket_getopt
- socket_getpeername
- socket_getsockname
- socket_import_stream
- socket_last_error
- socket_listen
- socket_read
- socket_recv
- socket_recvfrom
- socket_recvmsg
- socket_select
- socket_send
- socket_sendmsg
- socket_sendto
- socket_set_block
- socket_set_nonblock
- socket_set_option
- socket_setopt
- socket_shutdown
- socket_strerror
- socket_write
Коментарии
Curiously, getsockname() works for socket_create() and socket_create_pair() Unix-domain (AF_UNIX) sockets if one calls socket_bind() after creation to name the formerly anonymous socket(s).
Using a socket_bind() call also results in a file system "file" (socket, first character 's' in an "ls -l" listing) being created with the given name. Such a "file" will need to be removed explicitly, as closing the socket will not remove it.