添加链接
link管理
链接快照平台
  • 输入网页链接,自动生成快照
  • 标签化管理网页链接
相关文章推荐
胆小的马克杯  ·  Quick start - ...·  2 周前    · 
酷酷的煎鸡蛋  ·  Golang WebSocket Ping ...·  14 小时前    · 
爽快的墨镜  ·  Websockets ...·  14 小时前    · 
性感的炒饭  ·  Qlik Sense: How to ...·  14 小时前    · 
大力的馒头  ·  Pumping Messages with ...·  14 小时前    · 
旅途中的拐杖  ·  概览·  1 月前    · 
Typedefs typedef int(* websocket_connect_cb_t ) (int ws_sock, struct http_request *req, void *user_data)  Callback called after Websocket connection is established.
Enumerations enum websocket_opcode {
WEBSOCKET_OPCODE_CONTINUE = 0x00 , WEBSOCKET_OPCODE_DATA_TEXT = 0x01 , WEBSOCKET_OPCODE_DATA_BINARY = 0x02 , WEBSOCKET_OPCODE_CLOSE = 0x08 WEBSOCKET_OPCODE_PING = 0x09 , WEBSOCKET_OPCODE_PONG = 0x0A  Websocket option codes. More...
Functions int websocket_connect (int http_sock, struct websocket_request *req, int32_t timeout, void *user_data)  Connect to a server that provides Websocket service.
int websocket_send_msg (int ws_sock, const uint8_t *payload, size_t payload_len, enum websocket_opcode opcode, bool mask, bool final, int32_t timeout)  Send websocket msg to peer.
int websocket_recv_msg (int ws_sock, uint8_t *buf, size_t buf_len, uint32_t *message_type, uint64_t *remaining, int32_t timeout)  Receive websocket msg from peer.
int websocket_disconnect (int ws_sock)  Close websocket.
int websocket_register (int http_sock, uint8_t *recv_buf, size_t recv_buf_len)  Register a socket as websocket.
int websocket_unregister (int ws_sock)  Unregister a websocket.

Detailed Description

Websocket API .

Since
1.12
Version
0.1.0

Macro Definition Documentation

WEBSOCKET_FLAG_BINARY

#include < zephyr/net/websocket.h >

Callback called after Websocket connection is established.

Parameters
ws_sockWebsocket id reqHTTP handshake request user_dataA valid pointer on some user data or NULL
Returns
0 if ok, <0 if there is an error and connection should be aborted

Enumeration Type Documentation

websocket_opcode

Enumerator WEBSOCKET_OPCODE_CONTINUE

Message continues.

WEBSOCKET_OPCODE_DATA_TEXT

Textual data.

WEBSOCKET_OPCODE_DATA_BINARY

Binary data.

WEBSOCKET_OPCODE_CLOSE

Closing connection.

WEBSOCKET_OPCODE_PING

Ping message.

WEBSOCKET_OPCODE_PONG

Pong message.

Connect to a server that provides Websocket service.

The callback is called after connection is established. The returned value is a new socket descriptor that can be used to send / receive data using the BSD socket API.

Parameters
http_sockSocket id to the server. Note that this socket is used to do HTTP handshakes etc. The actual Websocket connectivity is done via the returned websocket id. Note that the http_sock must not be closed after this function returns as it is used to deliver the Websocket packets to the Websocket server. reqWebsocket request. User should allocate and fill the request data. timeoutMax timeout to wait for the connection. The timeout value is in milliseconds. Value SYS_FOREVER_MS means to wait forever. user_dataUser specified data that is passed to the callback.
Returns
Websocket id to be used when sending/receiving Websocket data.

Close websocket.

One must call websocket_connect() after this call to re-establish the connection.

Parameters
ws_sockWebsocket id returned by websocket_connect() .
Returns
<0 if error, 0 the connection was closed successfully

Receive websocket msg from peer.

The function will automatically remove websocket header from the message.

Parameters
ws_sockWebsocket id returned by websocket_connect() . bufBuffer where websocket data is read. buf_lenLength of the data buffer. message_typeType of the message. remainingHow much there is data left in the message after this read. timeoutHow long to try to receive the message. The value is in milliseconds. Value SYS_FOREVER_MS means to wait forever.
Return values
>=0amount of bytes received. -EAGAINon timeout. -ENOTCONNon socket close. -errnoother negative errno value in case of failure.

Register a socket as websocket.

This is called by HTTP server when a connection is upgraded to a websocket connection.

Parameters
http_sockUnderlying socket connection socket. recv_bufTemporary receive buffer for websocket parsing. This must point to a memory area that is valid for the duration of the whole websocket session. recv_buf_lenLength of the temporary receive buffer.
Returns
<0 if error, >=0 the actual websocket to be used by application

Send websocket msg to peer.

The function will automatically add websocket header to the message.

Parameters
ws_sockWebsocket id returned by websocket_connect() . payloadWebsocket data to send. payload_lenLength of the data to be sent. opcodeOperation code (text, binary, ping, pong, close) maskMask the data, see RFC 6455 for details finalIs this final message for this message send. If final == false, then the first message must have valid opcode and subsequent messages must have opcode WEBSOCKET_OPCODE_CONTINUE. If final == true and this is the only message, then opcode should have proper opcode (text or binary) set. timeoutHow long to try to send the message. The value is in milliseconds. Value SYS_FOREVER_MS means to wait forever.
Returns
<0 if error, >=0 amount of bytes sent

Unregister a websocket.

This is called when we no longer need the underlying "real" socket. This will close first the websocket and then the original socket.

Parameters
ws_sockWebsocket connection socket.
Returns
<0 if error, 0 the websocket connection is now fully closed