企业🤖AI智能体构建引擎,智能编排和调试,一键部署,支持私有化部署方案 广告
<span style="color:blue">**socket_accept**</span>(resource **$socket**) :resource 客户端通过socket_connect开启一个套接字连接,服务端则通过此函数socket_accept接受客户端的链接,它的参数是服务端的套接字 成功返回套接字的信息资源,失败为false,默认是阻塞的他会一直等待客户端的socket_connect链接成功连接后返回客户端的套接字 如果有多个客户端等待连接则先与第一个客户端通信,其他会阻塞的等待着。如果`socket`已使用[socket\_set\_blocking()](https://www.php.net/manual/en/function.socket-set-blocking.php)或[socket\_set\_nonblock()](https://www.php.net/manual/en/function.socket-set-nonblock.php)进行了非阻塞,则将返回**`FALSE`**可以通过调用[socket\_last\_error()](https://www.php.net/manual/en/function.socket-last-error.php)来检索实际的错误代码。可以将此错误代码传递给[socket\_strerror()](https://www.php.net/manual/en/function.socket-strerror.php)以获得错误的文本说明 ![](https://img.kancloud.cn/32/54/325416ac992c75d9988b46f3514f8aea_489x482.png) cli执行php server.php后是阻塞状态,不会输出111 ``` $socket=socket_create(AF_INET, SOCK_STREAM, getprotobyname('tcp')); socket_bind($socket,'127.0.0.1',8080); socket_listen($socket,4); $client_socket = socket_accept($socket); //默认阻塞的,代码在这停留,除非接受到客户端通过socket_connect的开启一个套接字连接请求才会往下执行 echo 111; ``` 开启非阻塞后不在阻塞的的等待客户端的链接了,而是直接执行下面的代码 cli执行php server.php后直接输出111 ``` $socket=socket_create(AF_INET, SOCK_STREAM, getprotobyname('tcp')); socket_bind($socket,'127.0.0.1',8080); socket_listen($socket,4); socket_set_nonblock($socket); $client_socket = socket_accept($socket); //默认阻塞的,代码在这停留,除非接受到客户端通过socket_connect的开启一个套接字连接请求才会往下执行 echo 111; ``` 由上面的例子可以看出多个客户端连接时,需要通过while(true)循环检测客户端的链接 ``` //如果要在一台服务器上有多个客户端,则必须使用非阻塞 $clients = array(); $socket = socket_create(AF_INET,SOCK_STREAM,SOL_TCP); socket_bind($socket,'127.0.0.1',$port); socket_listen($socket); socket_set_nonblock($socket); while(true) { if(($newc = socket_accept($socket)) !== false) { echo "Client $newc has connected\n"; $clients[] = $newc; } } ``` 例子2: ``` //服务端脚本,server_socket.php  //创建服务端的socket套接流,net协议为IPv4,protocol协议为TCP $socket = socket_create(AF_INET,SOCK_STREAM,SOL_TCP); /*绑定接收的套接流主机和端口,与客户端相对应*/ if(socket_bind($socket,'127.0.0.1',8888) == false){ echo 'server bind fail:'.socket_strerror(socket_last_error()); /*这里的127.0.0.1是在本地主机测试,你如果有多台电脑,可以写IP地址*/ } //监听套接流 最大监听4个套接流 if(socket_listen($socket,4)==false){ echo 'server listen fail:'.socket_strerror(socket_last_error()); } //让服务器无限获取客户端传过来的信息 do{ /*接收客户端传过来的信息*/ $accept_resource = socket_accept($socket); /*socket_accept的作用就是接受socket_bind()所绑定的主机发过来的套接流*/ if($accept_resource !== false){ /*读取客户端传过来的资源,并转化为字符串*/ $string = socket_read($accept_resource,1024); /*socket_read的作用就是读出socket_accept()的资源并把它转化为字符串*/ echo 'server receive is :'.$string.PHP_EOL;//PHP_EOL为php的换行预定义常量 if($string != false){ $return_client = 'server receive is : '.$string.PHP_EOL; /*向socket_accept的套接流写入信息,也就是回馈信息给socket_bind()所绑定的主机客户端*/ socket_write($accept_resource,$return_client,strlen($return_client)); /*socket_write的作用是向socket_create的套接流写入信息,或者向socket_accept的套接流写入信息*/ }else{ echo 'socket_read is fail'; } /*socket_close的作用是关闭socket_create()或者socket_accept()所建立的套接流*/ socket_close($accept_resource); } }while(true); socket_close($socket); //请注意上面的socket_bind,socket_listen,socket_accept三个函数的执行顺序不可更改 //客户端脚本,client_socket.php //创建一个socket套接流 $socket = socket_create(AF_INET,SOCK_STREAM,SOL_TCP); /****************设置socket连接选项,这两个步骤你可以省略*************/ //接收套接流的最大超时时间1秒,后面是微秒单位超时时间,设置为零,表示不管它 socket_set_option($socket, SOL_SOCKET, SO_RCVTIMEO, array("sec" => 1, "usec" => 0)); //发送套接流的最大超时时间为6秒 socket_set_option($socket, SOL_SOCKET, SO_SNDTIMEO, array("sec" => 6, "usec" => 0)); /****************设置socket连接选项,这两个步骤你可以省略*************/ //连接服务端的套接流,这一步就是使客户端与服务器端的套接流建立联系 if(socket_connect($socket,'127.0.0.1',8888) == false){ echo 'connect fail massege:'.socket_strerror(socket_last_error()); }else{ $message = 'l love you 我爱你 socket'; //转为GBK编码,处理乱码问题,这要看你的编码情况而定,每个人的编码都不同 $message = mb_convert_encoding($message,'GBK','UTF-8'); //向服务端写入字符串信息 if(socket_write($socket,$message,strlen($message)) == false){ echo 'fail to write'.socket_strerror(socket_last_error()); }else{ echo 'client write success'.PHP_EOL; //读取服务端返回来的套接流信息 while($callback = socket_read($socket,1024)){ echo 'server return message is:'.PHP_EOL.$callback; } } } socket_close($socket);//工作完毕,关闭套接流 ```