Función WsRequestReply (webservices.h)
Se usa para enviar un mensaje de solicitud y recibir un mensaje de respuesta correlacionado.
Sintaxis
HRESULT WsRequestReply(
[in] WS_CHANNEL *channel,
[in] WS_MESSAGE *requestMessage,
[in] const WS_MESSAGE_DESCRIPTION *requestMessageDescription,
[in] WS_WRITE_OPTION writeOption,
const void *requestBodyValue,
[in] ULONG requestBodyValueSize,
[in] WS_MESSAGE *replyMessage,
[in] const WS_MESSAGE_DESCRIPTION *replyMessageDescription,
[in] WS_READ_OPTION readOption,
[in, optional] WS_HEAP *heap,
void *value,
[in] ULONG valueSize,
[in, optional] const WS_ASYNC_CONTEXT *asyncContext,
[in, optional] WS_ERROR *error
);
Parámetros
[in] channel
Canal en el que se va a realizar la operación request-reply.
[in] requestMessage
Objeto de mensaje que se va a usar para enviar la solicitud.
El objeto message debe estar en WS_MESSAGE_STATE_EMPTY o WS_MESSAGE_STATE_INITIALIZED.
[in] requestMessageDescription
El campo de acción del WS_MESSAGE_DESCRIPTION se usa como encabezado de acción para el mensaje de solicitud. Este campo puede ser NULL si no se requiere ninguna acción.
El campo bodyElementDescription del WS_MESSAGE_DESCRIPTION se usa para serializar el cuerpo del mensaje de solicitud. Este campo puede ser NULL si no se desea ningún elemento body. Consulte WsWriteBody para obtener información sobre cómo se serializa el cuerpo según bodyElementDescription.
[in] writeOption
Indica si se requiere el elemento body y cómo se asigna el valor. Consulte WS_WRITE_OPTION para obtener más información.
requestBodyValue
Puntero al valor que se va a serializar en el cuerpo del objeto de solicitud.
[in] requestBodyValueSize
Tamaño del valor de solicitud que se serializa, en bytes.
[in] replyMessage
Objeto de mensaje que se va a usar para recibir la respuesta.
El objeto message debe estar en WS_MESSAGE_STATE_EMPTY.
[in] replyMessageDescription
El campo de acción del WS_MESSAGE_DESCRIPTION se usa para comprobar el encabezado de acción del mensaje de respuesta recibido. Este campo puede ser NULL si no se requiere ninguna acción. Si es NULL, el encabezado de acción del mensaje recibido se omite si está presente.
El campo bodyElementDescription del WS_MESSAGE_DESCRIPTION se usa para deserializar el cuerpo del mensaje de respuesta. Este campo puede ser NULL si no se desea ningún elemento body. Consulte WsReadBody para obtener información sobre cómo se deserializa el cuerpo según bodyElementDescription.
[in] readOption
Indica si se requiere el elemento body de respuesta y cómo asignar el valor. Para obtener más información, vea WS_READ_OPTION y WsReadBody.
[in, optional] heap
Montón usado para asignar valores de cuerpo de respuesta deserializados. Si el montón no es necesario para el tipo especificado, este parámetro puede ser NULL.
value
Dónde almacenar los valores deserializados del cuerpo.
La interpretación de este parámetro depende del WS_READ_OPTION.
Si bodyElementDescription del WS_MESSAGE_DESCRIPTION de respuesta es NULL, este parámetro no se toca. En este caso, no es necesario especificar el parámetro .
[in] valueSize
La interpretación de este parámetro depende del WS_READ_OPTION.
[in, optional] asyncContext
Información sobre cómo invocar la función de forma asincrónica o NULL si invoca de forma sincrónica.
[in, optional] error
Especifica dónde se debe almacenar información de error adicional si se produce un error en la función.
Valor devuelto
Esta función puede devolver uno de estos valores.
Código devuelto | Descripción |
---|---|
|
El mensaje de respuesta contenía un error. El error se puede extraer del WS_ERROR mediante WsGetErrorProperty. |
|
La operación asincrónica sigue pendiente. |
|
Se anuló la operación. |
|
No se permite la operación debido al estado actual del objeto . |
|
El punto de conexión remoto no existe o no se pudo encontrar. |
|
El punto de conexión remoto denegó el acceso. |
|
Se finalizó la conexión con el punto de conexión remoto. |
|
El punto de conexión remoto no pudo procesar la solicitud. |
|
El punto de conexión remoto no está actualmente en servicio en esta ubicación. |
|
El punto de conexión remoto no puede procesar la solicitud debido a la sobrecarga. |
|
No se pudo acceder al punto de conexión remoto. |
|
La dirección URL de la dirección del punto de conexión no es válida. |
|
Los datos de entrada no tenían el formato esperado o no tenían el valor esperado. |
|
La operación no se completó dentro del tiempo asignado. |
|
El servidor proxy HTTP denegó el acceso. |
|
El servidor proxy HTTP no pudo procesar la solicitud. |
|
Se superó una cuota. |
|
La comprobación de seguridad no se realizó correctamente para los datos recibidos. |
|
Error en una operación de seguridad en el marco de servicios web de Windows. |
|
El servidor rechazó un token de seguridad porque ha expirado. |
|
El servidor proxy HTTP requiere el esquema de autenticación HTTP "básico". |
|
El servidor proxy HTTP requiere el esquema de autenticación HTTP 'digest'. |
|
El servidor proxy HTTP requiere el esquema de autenticación HTTP "negotiate". |
|
El servidor proxy HTTP requiere el esquema de autenticación HTTP "NTLM". |
|
El punto de conexión remoto requiere el esquema de autenticación HTTP "básico". |
|
El punto de conexión remoto requiere el esquema de autenticación HTTP "digest". |
|
El punto de conexión remoto requiere el esquema de autenticación HTTP "negotiate". |
|
El punto de conexión remoto requiere el esquema de autenticación HTTP "NTLM". |
|
Un certificado necesario no está dentro de su período de validez al comprobar con el reloj del sistema actual o la marca de tiempo en el archivo firmado. |
|
El nombre CN de los certificados no coincide con el valor pasado. |
|
Cadena de certificados procesada, pero terminada en un certificado raíz que no es de confianza para el proveedor de confianza. |
|
El certificado no es válido para el uso solicitado. |
|
La función de revocación no pudo comprobar la revocación debido a que el servidor de revocación estaba sin conexión. |
|
Se quedó sin memoria. |
|
Uno o más argumentos no son válidos. |
|
Esta función puede devolver otros errores no enumerados anteriormente. |
Comentarios
Los mensajes se correlacionan según corresponda con el WS_ADDRESSING_VERSION. Consulte Información general sobre la capa de canal para obtener más información sobre cómo correlacionar los mensajes de respuesta de solicitud.
Requisitos
Requisito | Value |
---|---|
Cliente mínimo compatible | Windows 7 [aplicaciones de escritorio | Aplicaciones para UWP] |
Servidor mínimo compatible | Windows Server 2008 R2 [aplicaciones de escritorio | Aplicaciones para UWP] |
Plataforma de destino | Windows |
Encabezado | webservices.h |
Library | WebServices.lib |
Archivo DLL | WebServices.dll |