socket_getsockname

(PHP 4 >= 4.1.0, PHP 5, PHP 7, PHP 8)

socket_getsocknameConsulta o lado local do soquete fornecido, o que pode resultar em servidor/porta ou em um caminho do sistema de arquivos Unix, dependendo do seu tipo

Descrição

socket_getsockname(Socket $socket, string &$address, int &$port = null): bool

Nota: socket_getsockname() não deve ser usado com soquetes AF_UNIX criados com socket_connect(). Somente soquetes criados com socket_accept() ou um soquete de servidor primário após uma chamada a socket_bind() retornarão valores significativos.

Parâmetros

socket

Uma instância de Socket criada com socket_create() ou socket_accept().

address

Se o soquete fornecido for do tipo AF_INET ou AF_INET6, socket_getsockname() retornará o endereço IP local na notação apropriada (por exemplo, 127.0.0.1 ou fe80::1) no parâmetro address e, se o parâmetro opcional port estiver presente, retornará também a porta associada.

Se o soquete fornecido for do tipo AF_UNIX, socket_getsockname() retornará o caminho do sistema de arquivos Unix (por exemplo, /var/run/daemon.sock) no parâmetro address.

port

Se fornecida, esta variável conterá a porta associada.

Valor Retornado

Retorna true em caso de sucesso ou false em caso de falha. socket_getsockname() pode também retornar false se o tipo de soquete não for AF_INET, AF_INET6 ou AF_UNIX. Neste caso, o último código de erro de soquete NÃO É atualizado.

Registro de Alterações

Versão Descrição
8.0.0 O parâmetro socket agora espera uma instância de Socket; anteriormente, um resource era esperado.

Veja Também

adicione uma nota

Notas Enviadas por Usuários (em inglês) 1 note

up
0
CXJ
10 years ago
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.
To Top