Función de devolución de llamada LPWSPASYNCSELECT (ws2spi.h)
El LPWSPAsyncSelect función solicita la notificación de eventos basada en mensajes de Windows de eventos de red para un socket.
Sintaxis
LPWSPASYNCSELECT Lpwspasyncselect;
int Lpwspasyncselect(
[in] SOCKET s,
[in] HWND hWnd,
[in] unsigned int wMsg,
[in] long lEvent,
[out] LPINT lpErrno
)
{...}
Parámetros
[in] s
Descriptor que identifica el socket para el que se requiere la notificación de eventos.
[in] hWnd
Controle la identificación de la ventana que debe recibir un mensaje cuando se produce un evento de red.
[in] wMsg
Mensaje que se va a enviar cuando se produce un evento de red.
[in] lEvent
Máscara de bits que especifica una combinación de eventos de red en los que está interesado el cliente de interfaz de proveedor de servicios (SPI) de Windows Sockets. Construido mediante el operador OR bit a bit con cualquiera de estos valores.
Valor | Significado |
---|---|
|
Emite la notificación de preparación para la lectura. |
|
Emite la notificación de preparación para escribir. |
|
Notificación de problemas de la llegada de datos de OOB. |
|
Emite la notificación de las conexiones entrantes. |
|
Emite la notificación de las conexiones completadas. |
|
Notificación de problemas de cierre de sockets. |
|
Problemas de notificación de la calidad del socket de los cambios del servicio (QoS). |
|
Reservado. |
|
Emite la notificación del cambio de interfaz de enrutamiento para el destino especificado. |
|
Emite la notificación del cambio de lista de direcciones local para la familia de protocolos del socket. |
[out] lpErrno
Puntero al código de error. Consulte la sección valor devuelto
Valor devuelto
El valor devuelto es cero si la declaración de interés del cliente SPI de Windows Sockets en el conjunto de eventos de red se realizó correctamente. De lo contrario, se devuelve el valor SOCKET_ERROR y hay disponible un código de error específico en lpErrno.
Código de error | Significado |
---|---|
Error en el subsistema de red. | |
Indica que uno de los parámetros especificados no era válido, como el identificador de ventana que no hace referencia a una ventana existente o que el socket especificado está en un estado no válido. | |
Una llamada de Bloqueo de Windows Sockets está en curso o el proveedor de servicios sigue procesando una función de devolución de llamada. | |
El descriptor no es un socket. |
Consulte Comentarios para obtener información sobre códigos de error adicionales que se pueden establecer (en la palabra alta de lParam dentro del mensaje) cuando una ventana de la aplicación recibe un mensaje.
Observaciones
Esta función se usa para solicitar que el proveedor de servicios envíe un mensaje de Windows a la ventana del cliente hWnd siempre que el proveedor de servicios detecte cualquiera de los eventos de red especificados por el argumento lEvent. El proveedor de servicios debe usar la función WPUPostMessage
Esta función establece automáticamente el de socket
Invocar LPWSPAsyncSelect para un socket cancela cualquier LPWSPAsyncSelect o LPWSPEventSelect para el mismo socket. Por ejemplo, para recibir notificaciones de lectura y escritura, el cliente SPI de Windows Sockets debe llamar a LPWSPAsyncSelect con FD_READ y FD_WRITE, como este.
rc = WSPAsyncSelect(s, hWnd, wMsg, FD_READ | FD_WRITE, &error);
No es posible especificar mensajes diferentes para eventos diferentes. El código siguiente no funcionará; la segunda llamada cancela los efectos del primero y la única asociación será el evento FD_WRITE asociado a wMsg2.
// Incorrect example.
rc = WSPAsyncSelect(s, hWnd, wMsg1, FD_READ, &error);
rc = WSPAsyncSelect(s, hWnd, wMsg2, FD_WRITE, &error);
Para cancelar todas las notificaciones (es decir, para indicar que el proveedor de servicios no debe enviar más mensajes relacionados con eventos de red en el socket), establezca lEvent en cero.
rc = WSPAsyncSelect(s, hWnd, 0, 0, &error);
Dado que un LPWSPAccept'ed socket tiene las mismas propiedades que el socket de escucha usado para aceptarlo, cualquier LPWSPAsyncSelect eventos establecidos para el socket de escucha se aplica al socket aceptado. Por ejemplo, si un socket de escucha tiene LPWSPAsyncSelect eventos FD_ACCEPT, FD_READ y FD_WRITE, cualquier socket aceptado en ese socket de escucha también tendrá FD_ACCEPT, FD_READ y eventos FD_WRITE con el mismo wMsg valor usado para los mensajes. Si se desea otro wMsg o eventos, el cliente SPI de Windows Sockets debe llamar a LPWSPAsyncSelect, pasando el socket aceptado y la nueva información deseada.
Cuando se produce uno de los eventos de red designados en eldel socket especificado
Valor | Significado |
---|---|
FD_READ | El de socket |
FD_WRITE | El de socket |
FD_OOB | Los datos fuera de banda están listos para leer en de sockets |
FD_ACCEPT | Socket s está listo para aceptar una nueva conexión entrante |
FD_CONNECT | Se ha completado la conexión que se inició en el socket s. |
FD_CLOSE | Se ha cerrado la conexión identificada por de socket |
FD_QOS | La calidad del servicio asociado al de sockets |
FD_GROUP_QOS | Reservado para uso futuro con grupos de sockets: la calidad del servicio asociado al grupo de sockets al que pertenece el socket s ha cambiado |
FD_ROUTING_INTERFACE_CHANGE | La interfaz local que se debe usar para enviar al destino especificado ha cambiado. |
FD_ADDRESS_LIST_CHANGE | La lista de direcciones de la familia de protocolos del socket al que el cliente SPI de Windows Sockets puede enlazar ha cambiado. |
La palabra alta de ws2spi.h
. Los códigos de error posibles para cada evento de red se muestran en la tabla siguiente.
evento : FD_CONNECT
Código de error | Significado |
---|---|
Las direcciones de la familia especificada no se pueden usar con este socket. | |
Se rechazó el intento de conexión. | |
No se puede acceder a la red desde este host en este momento. | |
El parámetro namelen no es válido. | |
El socket ya está enlazado a una dirección. | |
El socket ya está conectado. | |
No hay más descriptores de archivo disponibles. | |
No hay espacio de búfer disponible. El socket no se puede conectar. | |
El socket no está conectado. | |
Se agota el tiempo de espera de conexión sin establecer una conexión. |
evento : FD_CLOSE
Código de error | Significado |
---|---|
|
Error en el subsistema de red. |
La conexión se restableció por el lado remoto. | |
La conexión se finalizó debido a un tiempo de espera u otro error. |
Evento...: FD_ACCEPT, FD_ADDRESS_LIST_CHANGE, FD_GROUP_QOS, FD_OOB, FD_QOS, FD_READ, FD_WRITE
Código de error | Significado |
---|---|
|
Error en el subsistema de red. |
evento : FD_ROUTING_INTERFACE_CHANGE
Código de error | Significado |
---|---|
El destino especificado ya no es accesible. | |
|
Error en el subsistema de red. |
Aunque se puede llamar a LPWSPAsyncSelect con interés en varios eventos, el proveedor de servicios emite el mismo mensaje de Windows para cada evento.
Un proveedor de Windows Sockets 2 no debe inundar continuamente un cliente SPI de Windows Sockets con mensajes para un evento de red determinado. Después de haber publicado correctamente una notificación de un evento determinado en una ventana de cliente SPI de Windows Sockets, no se publicará ningún mensaje adicional para ese evento de red en la ventana del cliente SPI de Windows Sockets hasta que el cliente SPI de Windows Sockets realice la llamada de función que vuelve a habilitar implícitamente la notificación de ese evento de red.
Evento de red | Volver a habilitar la función |
---|---|
FD_READ | LPWSPRecv o LPWSPRecvFrom |
FD_WRITE | LPWSPSend o LPWSPSendTo |
FD_OOB | LPWSPRecv o LPWSPRecvFrom |
FD_ACCEPT | LPWSPAccept, a menos que el código de error devuelto sea WSATRY_AGAIN que indique que la función condition devolvió CF_DEFER |
FD_CONNECT | NINGUNO |
FD_CLOSE | NINGUNO |
FD_QOS | LPWSPIoctl con SIO_GET_QOS |
FD_GROUP_QOS | Reservado para uso futuro con grupos de sockets: LPWSPIoctl con SIO_GET_GROUP_QOS |
FD_ROUTING_INTERFACE_CHANGE | LPWSPIoctl con SIO_ROUTING_INTERFACE_CHANGE de comandos |
FD_ADDRESS_LIST_CHANGE | LPWSPIoctl con SIO_ADDRESS_LIST_CHANGE de comandos |
Cualquier llamada a la rutina de volver a habilitar, incluso una que produce un error, da como resultado volver a habilitar la publicación de mensajes para el evento pertinente.
Para eventos de FD_READ, FD_OOB y FD_ACCEPT, la publicación de mensajes se desencadenada por el nivel . Esto significa que si se llama a la rutina de volver a habilitar y se sigue cumpliendo la condición pertinente después de la llamada, se publica un mensaje de LPWSPAsyncSelect al cliente SPI de Windows Sockets.
Los eventos FD_QOS y FD_GROUP_QOS se consideran desencadenados por el perímetro. Un mensaje se publicará exactamente una vez cuando se produzca un cambio de QOS. Los mensajes adicionales no estarán disponibles hasta que el proveedor detecte un cambio adicional en QOS o el cliente SPI de Windows Sockets renegocia el QOS para el socket.
Los eventos FD_ROUTING_INTERFACE_CHANGE y FD_ADDRESS_LIST_CHANGE también se consideran desencadenados por el perímetro. Un mensaje se publicará exactamente una vez cuando se produzca un cambio después de que el cliente SPI de Windows Sockets haya solicitado la notificación emitiendo WSAIoctl con SIO_ROUTING_INTERFACE_CHANGE o SIO_ADDRESS_LIST_CHANGE correspondientes. Los mensajes adicionales no estarán disponibles hasta que el cliente SPI de Windows Sockets vuelva a emitir el de IOCTL y se detecte otro cambio desde que se ha emitido el IOCTL.
Si ya se ha producido algún evento cuando el cliente SPI de Windows Sockets llama a LPWSPAsyncSelect, o cuando se llama a la función de re-habilitación, se publica un mensaje según corresponda. Por ejemplo, considere la siguiente secuencia.
- Un cliente SPI de Windows Sockets llama a LPWSPListen.
- Se recibe una solicitud de conexión, pero aún no se acepta.
- El cliente SPI de Windows Sockets llama a LPWSPAsyncSelect especificando que quiere recibir mensajes FD_ACCEPT para el socket. Debido a la persistencia de eventos, el proveedor de servicios de WinSock publica inmediatamente un mensaje FD_ACCEPT.
El evento FD_WRITE se controla de forma ligeramente diferente. Se publica un mensaje FD_WRITE cuando un socket se conecta por primera vez con LPWSPConnect (después de FD_CONNECT, si también está registrado) o se acepta con LPWSPAccepty después de un LPWSPSend o LPWSPSendTo produce un error con WSAEWOULDBLOCK y el espacio de búfer está disponible. Por lo tanto, un cliente SPI de Windows Sockets puede suponer que los envíos son posibles a partir del primer mensaje de FD_WRITE y duradero hasta que un envío devuelve WSAEWOULDBLOCK. Después de este error, se notificará al cliente SPI de Windows Sockets que los envíos son posibles de nuevo con un mensaje de FD_WRITE.
El evento FD_OOB solo se usa cuando un socket está configurado para recibir datos fuera de banda por separado. Si el socket está configurado para recibir datos fuera de banda en línea, los datos fuera de banda (acelerados) se tratan como datos normales y el cliente SPI de Windows Sockets debe registrar un interés en FD_READ eventos, no FD_OOB eventos.
El código de error de un mensaje de FD_CLOSE indica si el cierre del socket era correcto o anulativo. Si el código de error es 0, el cierre era correcto; Si el código de error es WSAECONNRESET, se restablece el circuito virtual del socket. Esto solo se aplica a sockets orientados a la conexión, como SOCK_STREAM.
El mensaje FD_CLOSE se publica cuando se recibe una indicación de cierre para el circuito virtual correspondiente al socket. En términos TCP, esto significa que el FD_CLOSE se publica cuando la conexión entra en los estados TIME WAIT o CLOSE WAIT. Esto resulta del extremo remoto que realiza una de LPWSPShutdown de
En el caso de un cierre correcto, el proveedor de servicios debe enviar un mensaje de FD_CLOSE para indicar el cierre del circuito virtual solo después de leer todos los datos recibidos. No debe enviar un mensaje de FD_READ para indicar esta condición.
El mensaje FD_QOS o FD_GROUP_QOS se publica cuando se ha producido un cambio en cualquier campo de la especificación de flujo asociada a ladel socket
El mensaje FD_ROUTING_INTERFACE_CHANGE se publica cuando la interfaz local que se debe usar para llegar al destino especificado en LPWSPIoctl con SIO_ROUTING_INTERFACE_CHANGE cambios después de se ha emitido dicho IOCTL.
El mensaje FD_ADDRESS_LIST_CHANGE se publica cuando se publica la lista de direcciones a las que el cliente SPI de Windows Sockets puede enlazar los cambios después delpWSPIoctl con SIO_ADDRESS_LIST_CHANGE se ha emitido.
Este es un resumen de los eventos y condiciones de cada mensaje de notificación asincrónico.
FD_READ
- Cuando se llama a LPWSPAsyncSelect, si hay datos disponibles actualmente para recibir.
- Cuando llegan los datos, si FD_READ aún no se han publicado.
- Después de se llama a LPWSPRecv o LPWSPRecvFrom (con o sin MSG_PEEK), si los datos siguen estando disponibles para recibirse.
Cuando se habilita SO_OOBINLINE LPWSPSetSockOpt, datos incluye datos normales y datos fuera de banda (OOB) en las instancias indicadas anteriormente.
FD_WRITE
- Cuando se llama a LPWSPAsyncSelect, si es posible un LPWSPSend o LPWSPSendTo.
- Después de LPWSPConnect o se llama al LPWSPAccept, cuando se establece la conexión.
- Después de LPWSPSend o LPWSPSendTo produzca un error con WSAEWOULDBLOCK, cuando LPWSPSend o LPWSPSendTo es probable que se realice correctamente.
- Después de LPWSPBind en un socket sin conexión. FD_WRITE puede ocurrir o no en este momento (dependiente de la implementación). En cualquier caso, un socket sin conexión siempre se puede escribir inmediatamente después de LPWSPBind.
FD_OOB (válido solo cuando LPWSPSetSockOpt SO_OOBINLINE está deshabilitado (valor predeterminado))
- Cuando se llama a LPWSPAsyncSelect, si hay datos OOB disponibles actualmente para recibirlos con la marca MSG_OOB.
- Cuando llegan los datos de OOB, si aún no FD_OOB publicados.
- Después de llamar a LPWSPRecv o LPWSPRecvFrom con o sin MSG_OOB marca, si los datos de OOB siguen estando disponibles para recibirse.
FD_ACCEPT
- Cuando se llama a LPWSPAsyncSelect, si actualmente hay una solicitud de conexión disponible para aceptar.
- Cuando llega una solicitud de conexión, si FD_ACCEPT aún no se ha publicado.
- Después de llamar a LPWSPAccept, si hay otra solicitud de conexión disponible para aceptar.
FD_CONNECT
- Cuando se llama a LPWSPAsyncSelect, si actualmente hay una conexión establecida.
- Después de llamar a LPWSPConnect, cuando se establece la conexión (incluso cuando LPWSPConnect se realiza correctamente inmediatamente, como sucede con un socket de datagrama) e incluso cuando se produce un error inmediatamente).
- Después de llamar a WSPJoinLeaf, cuando se completa la operación de combinación.
- Después de conectar, WSAConnect, o WSPJoinLeaf se llamó a con un socket orientado a conexiones sin bloqueo. La operación inicial devolvió un error específico de WSAEWOULDBLOCK, pero la operación de red se adelantó. Si la operación se realiza correctamente o no, cuando se ha determinado el resultado, FD_CONNECT se produce. El cliente debe comprobar el código de error para determinar si el resultado fue correcto o erróneo.
FD_CLOSE (válido solo en sockets orientados a conexiones (por ejemplo, SOCK_STREAM))
- Cuando se llama a LPWSPAsyncSelect, si se ha cerrado la conexión de socket.
- Después de que el sistema remoto haya iniciado un cierre correcto, cuando no haya datos disponibles actualmente para recibir (si se han recibido datos y está esperando que se lean cuando el sistema remoto inicia un cierre correcto, el FD_CLOSE no se entrega hasta que se hayan leído todos los datos pendientes).
- Una vez que el sistema local inicia un cierre correcto con
LPWSPShutdown y el sistema remoto ha respondido con una notificación de de fin de datos(como TCP FIN), cuando no hay datos disponibles para recibirse actualmente. - Cuando el sistema remoto anula la conexión (por ejemplo, TCP RST enviado) y lParam contendrá el valor de error WSAECONNRESET.
FD_CLOSE no se publica después de llamar al
FD_QOS
- Cuando se llama a LPWSPAsyncSelect, si se ha cambiado el QOS asociado al socket.
- Después de llamar a LPWSPIoctl con SIO_GET_QOS, cuando se cambia el QOS.
FD_GROUP_QOS
Reservado para uso futuro con grupos de sockets:
- Cuando se llama a LPWSPAsyncSelect, si se ha cambiado el grupo QOS asociado al socket.
- Después de se llama a LPWSPIoctl con SIO_GET_GROUP_QOS, cuando se cambia el grupo QOS.
FD_ROUTING_INTERFACE_CHANGE
- después de se llama a lpWSPIoctl con SIO_ROUTING_INTERFACE_CHANGE, cuando cambia la interfaz local que se debe usar para llegar al destino especificado en el IOCTL.
FD_ADDRESS_LIST_CHANGE
- después de se llama a LPWSPIoctl con SIO_ADDRESS_LIST_CHANGE, cuando se llama a la lista de direcciones locales a las que el cliente SPI de Windows Sockets puede enlazar los cambios.
Requisitos
Requisito | Valor |
---|---|
cliente mínimo admitido | Compilación 20348 de Windows 10 |
servidor mínimo admitido | Compilación 20348 de Windows 10 |
encabezado de |
ws2spi.h |