downloads | documentation | faq | getting help | mailing lists | licenses | wiki | reporting bugs | php.net sites | links | conferences | my php.net

search for in the

socket_import_stream> <socket_getpeername
[edit] Last updated: Fri, 25 May 2012

view this page in

socket_getsockname

(PHP 4 >= 4.1.0, PHP 5)

socket_getsockname指定したソケットのローカル側に問い合わせ、その型に応じてホスト/ポート、あるいは Unix ファイルシステムのパスを返す

説明

bool socket_getsockname ( resource $socket , string &$addr [, int &$port ] )

注意: socket_getsockname() は、 socket_accept() で作成した AF_UNIX ソケットとともに使用することはできません。意味のある値が返されるのは、 socket_accept() で作成したソケットか socket_bind() に続くプライマリサーバーソケットのみです。

パラメータ

socket

socket_create() あるいは socket_accept() で作成したソケットリソース。

addr

指定されたソケットの型が AF_INET あるいは AF_INET6 であった場合、socket_getsockname() はローカルの IP アドレス を適切な書式(例: 127.0.0.1 あるいは fe80::1)に したものを address パラメータに、そしてもし オプションの port パラメータが指定されていれば そこにポートを格納します。

指定されたソケットの型が AF_UNIX であった場合、 socket_getpeername() は Unix ファイルシステムのパス (例: /var/run/daemon.sock)を address パラメータに格納します。

port

指定した場合は、関連付けるポートを保持します。

返り値

成功した場合に TRUE を、失敗した場合に FALSE を返します。 socket_getsockname() は、 ソケットの型が AF_INETAF_INET6 あるいは AF_UNIX のいずれでもない場合にも FALSE を返します。この場合には、 直近のソケットエラーコードは更新されません

参考

  • socket_getpeername() - 指定したソケットのリモート側に問い合わせ、その型に応じてホスト/ポート、あるいは Unix ファイルシステムのパスを返す
  • socket_last_error() - ソケットの直近のエラーを返す
  • socket_strerror() - ソケットエラーの内容を文字列として返す



add a note add a note User Contributed Notes socket_getsockname
not at valid dot com 13-Oct-2007 12:35
Just a quick note:
I found socket_getsockname() is not IPv6 compatible or may just return some unexpected results?

<?php
Simple Code Example
:

$socket = socket_create(AF_INET,SOCK_STREAM,SOL_TCP);
   
socket_bind($socket,'0.0.0.0',150);

socket_getsockname($socket, $IP, $PORT);

print
$IP.":".$PORT."\n";

?>

This does not print $IP 127.0.0.1 or 192.168.1.1 or even 0.0.0.0 ... etc ... like you would expect ... in my case I receive 10.0.0.0 witch is not a valid port on my system using IPv5 and IPv6! Thus you should rely on using the initial values of socket_bind() to get the local address.

Hope this helps...

 
show source | credits | sitemap | contact | advertising | mirror sites