Partilhar via


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

Consulte também

Referência

Classe CAsyncSocket

Gráfico da hierarquia

CAsyncSocket::Connect

CAsyncSocket::GetLastError

CAsyncSocket::OnAccept

CAsyncSocket::OnClose

CAsyncSocket::OnOutOfBandData

CAsyncSocket::OnReceive

CAsyncSocket::OnSend