Movatterモバイル変換


[0]ホーム

URL:


API Overview
Docs
API: easyAPI: multiAPI: shareAPI: URLAPI: WebSocketEnvironment varsErrorsExamplesSecuritySymbolsTutorial
easy setopt optionseasy getinfo optionsmulti setopt optionsTLS options
Functions
All functionscurl_easy_getinfocurl_easy_initcurl_easy_performcurl_easy_resetcurl_easy_setoptcurl_multi_add_handlecurl_multi_initcurl_multi_performcurl_multi_remove_handlecurl_multi_setopt
curl /libcurl /API /WebSocket interface

WebSocket interface overview

Related:
All functions
API
Examples

Name

libcurl-ws - WebSocket interface overview

Description

The WebSocket interface provides functions for receiving and sending WebSocket data.

Include

You still only include <curl/curl.h> in your code.

Setup

WebSocket is also often known asWebSockets, in plural. It is done by upgrading a regular HTTP(S) GET request to a WebSocket connection.

WebSocket is a TCP-like message-based communication protocol done over HTTP, specified inRFC 6455.

To initiate a WebSocket session with libcurl, setup an easy handle to use a URL with a "WS://" or "WSS://" scheme. "WS" is for cleartext communication over HTTP and "WSS" is for doing WebSocket securely over HTTPS.

A WebSocket request is done as an HTTP/1 GET request with an "Upgrade WebSocket" request header field. When the upgrade is accepted by the server, it responds with a 101 Switching and then the client can speak WebSocket with the server. The communication can happen in both directions at the same time.

Extensions

The WebSocket protocol allows the client to request and negotiateextensions can add additional features and restrictions to the protocol.

libcurl does not support the use of extensions and always sets up a connection without them.

Messages

WebSocket communication is message based. That means that both ends send and receive entire messages, not streams like TCP. A WebSocket message is sent over the wire in one or more frames. A message which is split into several frames is referred to as afragmented message and the individual frames are calledfragments. Each frame (or fragment) in a message can have a size of up to 2^63 bytes and declares the frame size in the header. The total size of a message that is fragmented into multiple frames is not limited by the protocol and the number of fragments is not known until the final fragment is received.

Transmission of a frame must not be interrupted by any other data transfers and transmission of the different fragments of a message must not be interrupted by other user data frames. Control frames - PING, PONG and CLOSE - may be transmitted in between any other two frames, even in between two fragments of the same user data message. The control frames themselves on the other hand must never be fragmented and are limited to a size of 125 bytes.

libcurl delivers WebSocket data as chunks of frames. It might deliver a whole frame as a single chunk, but it might also deliver it in several pieces depending on size and network patterns. See the individual API documentations for further information.

Ping

WebSocket is designed to allow long-lived sessions and in order to keep the connections alive, both ends can send PING messages for the other end to respond with a PONG. Both ends may also send unsolicited PONG messages as unidirectional heartbeat.

libcurl automatically responds to server PING messages with a PONG that echoes the payload of the PING message. libcurl does neither send any PING messages nor any unsolicited PONG messages automatically.

Models

Because of the many different ways WebSocket can be used, which is much more flexible than limited to plain downloads or uploads, libcurl offers two different API models to use it:

1.CURLOPT_WRITEFUNCTION model: Using a write callback withCURLOPT_WRITEFUNCTION much like other downloads for when the traffic is download oriented.

2.CURLOPT_CONNECT_ONLY model: Usingcurl_ws_recv andcurl_ws_send functions.

CURLOPT_WRITEFUNCTION MODEL

CURLOPT_CONNECT_ONLY must be unset or0L for this model to take effect.

curl_easy_perform establishes and sets up the WebSocket communication and then blocks for the whole duration of the connection. libcurl calls the callback configured inCURLOPT_WRITEFUNCTION, whenever an incoming chunk of WebSocket data is received. The callback is handed a pointer to the payload data as an argument and can callcurl_ws_meta to get relevant metadata.

CURLOPT_CONNECT_ONLY MODEL

CURLOPT_CONNECT_ONLY must be2L for this model to take effect.

curl_easy_perform only establishes and sets up the WebSocket communication and then returns control back to the application. The application can then usecurl_ws_recv andcurl_ws_send to exchange WebSocket messages with the server.

Raw mode

libcurl can be told to speak WebSocket in "raw mode" by setting theCURLWS_RAW_MODE bit of theCURLOPT_WS_OPTIONS option.

Raw WebSocket means that libcurl passes on the data from the network without parsing it, leaving that entirely to the application.

This mode is intended for applications that already have a WebSocket parser/engine and want to switch over to use libcurl for enabling WebSocket, and keep parts of the existing software architecture.

See also

CURLOPT_CONNECT_ONLY(3),CURLOPT_WRITEFUNCTION(3),CURLOPT_WS_OPTIONS(3),curl_easy_init(3),curl_ws_meta(3),curl_ws_recv(3),curl_ws_send(3)

This HTML page was made withroffit.


[8]ページ先頭

©2009-2025 Movatter.jp