CAsyncSocket::OnConnect
Chamado pela estrutura para notificar este soquete conectando a tentativa de conexão, se estiver concluída com êxito ou o erro.
virtual void OnConnect(
int nErrorCode
);
Parâmetros
nErrorCode
O erro mais recente em um soquete. Os seguintes códigos de erro aplicam a OnConnect a função de membro:0 A função executada com êxito.
WSAEADDRINUSE o endereço especificado está sendo usado.
WSAEADDRNOTAVAIL o endereço especificado não está disponível no computador local.
Endereços deWSAEAFNOSUPPORT na família especificada não podem ser usados com esse soquete.
WSAECONNREFUSED a tentativa de se conectar foi descartado vigorosa.
O endereço de destino deWSAEDESTADDRREQ A é necessário.
WSAEFAULT o argumento de lpSockAddrLen está incorreto.
WSAEINVAL o soquete já esteja associado a um endereço.
WSAEISCONN o soquete já está conectado.
WSAEMFILE não mais descritores de arquivo está disponível.
WSAENETUNREACH a rede não pode ser alcançado de este host no momento.
WSAENOBUFS nenhum espaço de buffer está disponível. o soquete não pode ser conectado.
WSAENOTCONN o soquete não está conectado.
WSAENOTSOCK o descritor é um arquivo, não um soquete.
WSAETIMEDOUT a tentativa de conexão expirou sem estabelecer uma conexão.
Comentários
Dica
Em CSocket, a função de notificação de OnConnect é chamada nunca.Para conexões, você chama simplesmente Conectar, que devolverão quando a conexão for concluída com êxito (erro) ou no.Como as notificações de conexão são tratadas é um detalhes de implementação MFC.
Para obter mais informações, consulte Soquetes do windows: Notificações de soquete.
Exemplo
void CMyAsyncSocket::OnConnect(int nErrorCode) // CMyAsyncSocket is
// derived from CAsyncSocket
{
if (0 != nErrorCode)
{
switch(nErrorCode)
{
case WSAEADDRINUSE:
AfxMessageBox(_T("The specified address is already in use.\n"));
break;
case WSAEADDRNOTAVAIL:
AfxMessageBox(_T("The specified address is not available from ")
_T("the local machine.\n"));
break;
case WSAEAFNOSUPPORT:
AfxMessageBox(_T("Addresses in the specified family cannot be ")
_T("used with this socket.\n"));
break;
case WSAECONNREFUSED:
AfxMessageBox(_T("The attempt to connect was forcefully rejected.\n"));
break;
case WSAEDESTADDRREQ:
AfxMessageBox(_T("A destination address is required.\n"));
break;
case WSAEFAULT:
AfxMessageBox(_T("The lpSockAddrLen argument is incorrect.\n"));
break;
case WSAEINVAL:
AfxMessageBox(_T("The socket is already bound to an address.\n"));
break;
case WSAEISCONN:
AfxMessageBox(_T("The socket is already connected.\n"));
break;
case WSAEMFILE:
AfxMessageBox(_T("No more file descriptors are available.\n"));
break;
case WSAENETUNREACH:
AfxMessageBox(_T("The network cannot be reached from this host ")
_T("at this time.\n"));
break;
case WSAENOBUFS:
AfxMessageBox(_T("No buffer space is available. The socket ")
_T("cannot be connected.\n"));
break;
case WSAENOTCONN:
AfxMessageBox(_T("The socket is not connected.\n"));
break;
case WSAENOTSOCK:
AfxMessageBox(_T("The descriptor is a file, not a socket.\n"));
break;
case WSAETIMEDOUT:
AfxMessageBox(_T("The attempt to connect timed out without ")
_T("establishing a connection. \n"));
break;
default:
TCHAR szError[256];
_stprintf_s(szError, _T("OnConnect error: %d"), nErrorCode);
AfxMessageBox(szError);
break;
}
AfxMessageBox(_T("Please close the application"));
}
CAsyncSocket::OnConnect(nErrorCode);
}
Requisitos
Cabeçalho: afxsock.h