Condividi tramite


CAsyncSocket::ReceiveFromEx

Chiamare la funzione membro per ricevere un datagram e archiviare l'indirizzo di destinazione nella struttura SOCKADDR o in rSocketAddress (indirizzi IPv6 di handle).

int ReceiveFromEx( 
   void* lpBuf, 
   int nBufLen, 
   CString& rSocketAddress, 
   UINT& rSocketPort, 
   int nFlags = 0  
);

Parametri

  • lpBuf
    Un buffer dei dati in ingresso.

  • nBufLen
    La lunghezza lpBuf in byte.

  • rSocketAddress
    Riferimento a un oggetto CString che riceve un indirizzo IP tratteggiato del numero.

  • rSocketPort
    Riferimento a uint che archivia una porta.

  • nFlags
    Specifica la modalità in cui la chiamata viene eseguita. La semantica di questa funzione viene determinata dalle opzioni di socket e dal parametro nFlags. L'ultimo viene costruito combinando uno dei seguenti valori con l'operatore C++ OR :

    • Sbirciata diMSG_PEEK ai dati in ingresso. I dati vengono copiati nel buffer ma non vengono rimossi dalla coda di input.

    • Dati fuori banda di processo diMSG_OOB.

Valore restituito

Se non si verificano errori, ReceiveFromEx restituisce il numero di byte ricevuti. Se la connessione è stata chiusa, restituisce 0. In caso contrario, un valore SOCKET_ERROR viene restituito e un codice di errore specifico può essere recuperato chiamando GetLastError. Gli errori seguenti si applicano a questa funzione membro:

  • WSANOTINITIALISED Al AfxSocketInit deve verificarsi prima di utilizzare questa API.

  • WSAENETDOWN che l'implementazione di Windows Sockets ha rilevato che il sottosistema di rete non è riuscita.

  • WSAEFAULT l'argomento lpSockAddrLen non è valido: il buffer lpSockAddr è troppo piccolo per includere l'indirizzo peer.

  • WSAEINPROGRESS che blocca l'operazione di Windows Sockets è in corso.

  • IlWSAEINVAL socket non è stato associato a Associa.

  • IlWSAENOTCONN socket non è connessoSOCK_STREAM (solo).

  • WSAENOTSOCK il descrittore non è un socket.

  • WSAEOPNOTSUPP   MSG_OOB è stato specificato, ma il socket non è di tipo SOCK_STREAM.

  • IlWSAESHUTDOWN socket è stato interrotto; non è possibile chiamare ReceiveFromEx su un socket dopo ShutDown è stato richiamato con nHow impostato su 0 o 2.

  • IlWSAEWOULDBLOCK socket è contrassegnato come non bloccante e l'operazione ReceiveFromEx blocca.

  • IlWSAEMSGSIZE datagram è troppo grande per inserire nel buffer specificato ed è stato troncato.

  • IlWSAECONNABORTED circuito virtuale è stato interrotto a causa dell'intervallo o di altro tipo.

  • IlWSAECONNRESET circuito virtuale è stato reimpostato sul lato remoto.

Note

Questa funzione viene utilizzata per leggere i dati in ingresso su socket (eventualmente connessa) e per acquisire l'indirizzo che i dati inviati.

Questa funzione è la stessa CAsyncSocket::ReceiveFrom con la differenza che gestisce gli indirizzi IPv6 e protocolli più recenti.

Per i socket di tipo SOCK_STREAM, tutte le informazioni che sono attualmente disponibili finché la dimensione del buffer fornito vengono restituite. Se il socket è stato configurato per ricevere inline di dati fuori banda (opzione di socket SO_OOBINLINE) e i dati fuori banda non vengono letti, solo i dati fuori banda verranno restituiti. L'applicazione può utilizzare l'opzione o OnOutOfBandDataIOCtlSIOCATMARK determinare se altri dati fuori banda da leggere. I parametri lpSockAddrLen e lpSockAddr vengono ignorati per i socket SOCK_STREAM.

Per i socket di datagramma, i dati vengono estratti dal primo datagram enqueued, fino alla dimensione del buffer specificato. Se il datagram è più grande del buffer fornito, il buffer viene inserito prima parte del messaggio, i dati in eccesso vengono persi e ritorno ReceiveFromEx un valore SOCKET_ERROR con il codice di errore impostato su WSAEMSGSIZE.

Se lpSockAddr è diverso da zero e il socket è di tipo SOCK_DGRAM, l'indirizzo di rete di socket che ha inviato i dati viene copiato nella struttura corrispondente SOCKADDR. Il valore puntato da lpSockAddrLen viene inizializzato alla dimensione della struttura e viene modificato da restituire per indicare la dimensione effettiva dell'indirizzo archiviato in. Se non sono disponibili dati in ingresso disponibili a socket, attende di chiamata ReceiveFromEx i dati da arrivare a meno che il sia socket non bloccante. In questo caso, un valore SOCKET_ERROR viene restituito dal codice di errore impostato su WSAEWOULDBLOCK. Il callback OnReceive può essere utilizzato per determinare quando più dati arrivano.

Se il socket è di tipo SOCK_STREAM e il lato remoto chiude la connessione correttamente, ReceiveFromEx completata immediatamente ai 0 byte ricevuti.

Requisiti

Header: afxsock.h

Vedere anche

Riferimenti

Classe CAsyncSocket

Grafico delle gerarchie

CAsyncSocket::AsyncSelect

CAsyncSocket::Create

CAsyncSocket::Receive

CAsyncSocket::Send