websocket - websocket Client#
Adapted Air780E Air780EP Air780EPS
Note
This page document is automatically generated by this file. If there is any error, please submit issue or help modify pr, thank you!
Tip
This library has its own demo,click this link to view websocket demo examples
Example
local wsc = nil
if websocket then
wsc = websocket.create(nil, "ws://echo.airtun.air32.cn/ws/echo")
wsc:autoreconn(true, 3000) -- Automatic reconnection mechanism
wsc:on(function(wsc, event, data)
log.info("wsc", event, data)
if event == "conack" then
wsc:send((json.encode({action="echo", device_id=device_id})))
sys.publish("wsc_conack")
end
end)
wsc:connect()
--sys.waitUntil("websocket_conack", 15000)
while true do
sys.wait(45000)
if wsc:ready() then
wsc:send((json.encode({action="echo", msg=os.date()})))
end
end
wsc:close()
wsc = nil
end
wsc:debug(onoff)#
Configure whether to open debug information
Parameters
Incoming Value Type |
Explanation |
---|---|
boolean |
Whether to turn on debug switch |
Return Value
return value type |
explanation |
---|---|
nil |
No return value |
Examples
None
websocket.create(adapter, url, keepalive, use_ipv6)#
websocket Client Creation
Parameters
Incoming Value Type |
Explanation |
---|---|
int |
The serial number of the adapter. Refer to the constant of the socket library. The default value is nil. The method provided by the platform is selected. |
string |
connection strings, reference usage |
int |
Heartbeat interval, default 60 seconds. 2024.4.28 New |
boolean |
Whether to use ipv6, false. 2024.6.17 is added by default |
Return Value
return value type |
explanation |
---|---|
userdata |
Returns websocket client instance if successful, otherwise nil |
Examples
-- Common TCP Link
wsc = websocket.create(nil,"ws://air32.cn/abc")
-- Encrypted TCP Link
wsc = websocket.create(nil,"wss://air32.cn/abc")
wsc:on(cb)#
Register websocket Callback
Parameters
Incoming Value Type |
Explanation |
---|---|
function |
cb websocket callback, parameters include websocket_client, event, data, payload |
Return Value
return value type |
explanation |
---|---|
nil |
No return value |
Examples
wsc:on(function(websocket_client, event, data, payload)
-- Print various events
log.info("websocket", "event", event, data, payload)
end)
--[[
event The value has:
conack The connection to the server was successful, the websocket protocol header information has been received, and communication has been established.
recv Received information from the server, data, payload not nil
sent send The server has acknowledged receipt of the message sent by the function at the TCP protocol layer.
disconnect Server connection disconnected
The sent/disconnect event is added on 2023.04.01
]]
wsc:connect()#
Connection Server
Parameters
None
Return Value
return value type |
explanation |
---|---|
boolean |
Returns true if the launch is successful, otherwise false |
Examples
-- Start establishing a connection
wsc:connect()
-- This function only indicates that the launch is successful, and it is still necessary to determine whether the websocket is connected normally according to the ready function.
wsc:autoreconn(reconnect, reconnect_time)#
Automatic reconnect
Parameters
Incoming Value Type |
Explanation |
---|---|
bool |
Auto reconnect |
int |
Auto reconnect cycle unit ms default 3000ms |
Return Value
None
Examples
wsc:autoreconn(true)
wsc:send(data, fin, opt)#
Publish message
Parameters
Incoming Value Type |
Explanation |
---|---|
string |
Data to be sent, required |
int |
Whether it is the last frame, the default is 1, that is, it is immediately set to the last frame, that is, single frame transmission |
int |
Opcode, default is string frame 0, optional 1 |
Return Value
return value type |
explanation |
---|---|
bool |
Returns true on success, otherwise false, or nil |
Examples
-- Simple sending data
wsc:send("123")
-- Send data in segments, and finally use 1 (that is, the end of the FIN frame)
wsc:send("123", 0)
wsc:send("456", 0)
wsc:send("789", 1)
wsc:close()#
websocket Client shutdown (resources released after shutdown can no longer be used)
Parameters
None
Return Value
None
Examples
wsc:close()
wsc:ready()#
websocket Whether the client is ready
Parameters
None
Return Value
return value type |
explanation |
---|---|
bool |
Whether the client is ready |
Examples
local stat = wsc:ready()
wsc:headers(headers)#
Set additional headers
Parameters
Incoming Value Type |
Explanation |
---|---|
table/string |
It can be a table or a string. |
Return Value
return value type |
explanation |
---|---|
bool |
Whether the client is ready |
Examples
-- table Form
wsc:headers({
Auth="Basic ABCDEFGG"
})
-- string form
wsc:headers("Auth: Basic ABCDERG\r\n")