<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <HTML ><HEAD ><TITLE >socket_listen</TITLE ><META NAME="GENERATOR" CONTENT="Modular DocBook HTML Stylesheet Version 1.79"><LINK REL="HOME" TITLE="Manual do PHP" HREF="index.html"><LINK REL="UP" TITLE="Funções de Socket" HREF="ref.sockets.html"><LINK REL="PREVIOUS" TITLE="socket_last_error" HREF="function.socket-last-error.html"><LINK REL="NEXT" TITLE="socket_read" HREF="function.socket-read.html"><META HTTP-EQUIV="Content-type" CONTENT="text/html; charset=UTF-8"></HEAD ><BODY CLASS="refentry" BGCOLOR="#FFFFFF" TEXT="#000000" LINK="#0000FF" VLINK="#840084" ALINK="#0000FF" ><DIV CLASS="NAVHEADER" ><TABLE SUMMARY="Header navigation table" WIDTH="100%" BORDER="0" CELLPADDING="0" CELLSPACING="0" ><TR ><TH COLSPAN="3" ALIGN="center" >Manual do PHP</TH ></TR ><TR ><TD WIDTH="10%" ALIGN="left" VALIGN="bottom" ><A HREF="function.socket-last-error.html" ACCESSKEY="P" >Anterior</A ></TD ><TD WIDTH="80%" ALIGN="center" VALIGN="bottom" ></TD ><TD WIDTH="10%" ALIGN="right" VALIGN="bottom" ><A HREF="function.socket-read.html" ACCESSKEY="N" >Próxima</A ></TD ></TR ></TABLE ><HR ALIGN="LEFT" WIDTH="100%"></DIV ><H1 ><A NAME="function.socket-listen" ></A >socket_listen</H1 ><DIV CLASS="refnamediv" ><A NAME="AEN208600" ></A ><P > (PHP 4 >= 4.1.0, PHP 5)</P >socket_listen -- Abre escuta para uma conexão no socket</DIV ><DIV CLASS="refsect1" ><A NAME="AEN208603" ></A ><H2 >Descrição</H2 >bool <B CLASS="methodname" >socket_listen</B > ( resource socket [, int backlog] )<BR ></BR ><DIV CLASS="warning" ><P ></P ><TABLE CLASS="warning" BORDER="1" WIDTH="100%" ><TR ><TD ALIGN="CENTER" ><B >Atenção</B ></TD ></TR ><TR ><TD ALIGN="LEFT" ><P >Esta função é <SPAN CLASS="emphasis" ><I CLASS="emphasis" >EXPERIMENTAL</I ></SPAN >. Isso quer dizer que o comportamento desta função e seu nome, incluindo TUDO o que está documentado aqui pode mudar em futuras versões do PHP, SEM QUALQUER NOTIFICAÇÃO. Esteja avisado, e use esta função por sua própria conta e risco.</P ></TD ></TR ></TABLE ></DIV ><P > Após o socket <CODE CLASS="parameter" >socket</CODE > ter sido criado usando <A HREF="function.socket-create.html" ><B CLASS="function" >socket_create()</B ></A > e associado para um nome com <A HREF="function.socket-bind.html" ><B CLASS="function" >socket_bind()</B ></A >, ele deve dizer para aguardar por escuta em conexões que irão entrar <CODE CLASS="parameter" >socket</CODE >. </P ><P > Um máximo de <CODE CLASS="parameter" >backlog</CODE > em conexões entrantes irão ser listadas para este processamento. Se uma requisição de conexão chegar com um limite de clientes devem receber um erro com uma identificação de <TT CLASS="literal" >ECONNREFUSED</TT >, ou, se o protocolo abaixo suporta retransmissão, a requisição deve ser ignorada de forma até serem bem sucedidas. </P ><DIV CLASS="note" ><BLOCKQUOTE CLASS="note" ><P ><B >Nota: </B > O máximo número passado para o parâmetro <CODE CLASS="parameter" >backlog</CODE > altamente dependente da plataforma abaixo. No linux, isso é silenciosamente truncado para <TT CLASS="constant" ><B >SOMAXCONN</B ></TT >. No win32, se passado <TT CLASS="constant" ><B >SOMAXCONN</B ></TT >, o disponibilizador de serviço abaixo responsável pelo socket irá configurar o backlog para o valor máximo <SPAN CLASS="emphasis" ><I CLASS="emphasis" >reasonable</I ></SPAN >. Não há uma condição para procurar o valor do backlog atual nesta plataforma. </P ></BLOCKQUOTE ></DIV ><P > <B CLASS="function" >socket_listen()</B > é aplicável somente para sockets do tipo <TT CLASS="constant" ><B >SOCK_STREAM</B ></TT > ou <TT CLASS="constant" ><B >SOCK_SEQPACKET</B ></TT >. </P ><P > Retorna <TT CLASS="constant" ><B >TRUE</B ></TT > em caso de sucesso ou <TT CLASS="constant" ><B >FALSE</B ></TT > em falhas. O código de erro pode ser retornado com <A HREF="function.socket-last-error.html" ><B CLASS="function" >socket_last_error()</B ></A >. Isso código deve ser passado para <A HREF="function.socket-strerror.html" ><B CLASS="function" >socket_strerror()</B ></A > para pegar uma explicação textual do erro. </P ><P > Veja também <A HREF="function.socket-accept.html" ><B CLASS="function" >socket_accept()</B ></A >, <A HREF="function.socket-bind.html" ><B CLASS="function" >socket_bind()</B ></A >, <A HREF="function.socket-connect.html" ><B CLASS="function" >socket_connect()</B ></A >, <A HREF="function.socket-create.html" ><B CLASS="function" >socket_create()</B ></A > e <A HREF="function.socket-strerror.html" ><B CLASS="function" >socket_strerror()</B ></A >. </P ></DIV ><DIV CLASS="NAVFOOTER" ><HR ALIGN="LEFT" WIDTH="100%"><TABLE SUMMARY="Footer navigation table" WIDTH="100%" BORDER="0" CELLPADDING="0" CELLSPACING="0" ><TR ><TD WIDTH="33%" ALIGN="left" VALIGN="top" ><A HREF="function.socket-last-error.html" ACCESSKEY="P" >Anterior</A ></TD ><TD WIDTH="34%" ALIGN="center" VALIGN="top" ><A HREF="index.html" ACCESSKEY="H" >Principal</A ></TD ><TD WIDTH="33%" ALIGN="right" VALIGN="top" ><A HREF="function.socket-read.html" ACCESSKEY="N" >Próxima</A ></TD ></TR ><TR ><TD WIDTH="33%" ALIGN="left" VALIGN="top" >socket_last_error</TD ><TD WIDTH="34%" ALIGN="center" VALIGN="top" ><A HREF="ref.sockets.html" ACCESSKEY="U" >Acima</A ></TD ><TD WIDTH="33%" ALIGN="right" VALIGN="top" >socket_read</TD ></TR ></TABLE ></DIV ></BODY ></HTML >