main.lua 3.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. PROJECT = "airtun"
  2. VERSION = "1.0.0"
  3. -- sys库是标配
  4. _G.sys = require("sys")
  5. -- _G.sysplus = require("sysplus")
  6. ----------------------------------------
  7. -- 报错信息自动上报到平台,默认是iot.openluat.com
  8. -- 支持自定义, 详细配置请查阅API手册
  9. -- 开启后会上报开机原因, 这需要消耗流量,请留意
  10. if errDump then
  11. errDump.config(true, 600)
  12. end
  13. ----------------------------------------
  14. local wsc = nil
  15. sys.taskInit(function()
  16. sys.waitUntil("IP_READY") -- 等待联网成功
  17. -- 这是个测试服务, 当发送的是json,且action=echo,就会回显所发送的内容
  18. -- 加密TCP链接 wss 表示加密
  19. wsc = websocket.create(nil, "wss://echo.airtun.air32.cn/ws/echo")
  20. -- 这是另外一个测试服务, 能响应websocket的二进制帧
  21. -- wsc = websocket.create(nil, "ws://echo.airtun.air32.cn/ws/echo2")
  22. -- 以上两个测试服务是Java写的, 源码在 https://gitee.com/openLuat/luatos-airtun/tree/master/server/src/main/java/com/luatos/airtun/ws
  23. if wsc.headers then
  24. wsc:headers({Auth="Basic ABCDEGG"})
  25. end
  26. wsc:autoreconn(true, 3000) -- 自动重连机制
  27. wsc:on(function(wsc, event, data, fin, optcode)
  28. --[[
  29. event的值有:
  30. conack 连接服务器成功,已经收到websocket协议头部信息,通信已建立
  31. recv 收到服务器下发的信息, data, payload 不为nil
  32. sent send函数发送的消息,服务器在TCP协议层已确认收到
  33. disconnect 服务器连接已断开
  34. 其中 sent/disconnect 事件在 2023.04.01 新增
  35. ]]
  36. -- data 当事件为recv是有接收到的数据
  37. -- fin 是否为最后一个数据包, 0代表还有数据, 1代表是最后一个数据包
  38. -- optcode, 0 - 中间数据包, 1 - 文本数据包, 2 - 二进制数据包
  39. -- 因为lua并不区分文本和二进制数据, 所以optcode通常可以无视
  40. -- 若数据不多, 小于1400字节, 那么fid通常也是1, 同样可以忽略
  41. log.info("wsc", event, data, fin, optcode)
  42. -- 显示二进制数据
  43. -- log.info("wsc", event, data and data:toHex() or "", fin, optcode)
  44. if event == "conack" then -- 连接websocket服务后, 会有这个事件
  45. log.info("WebSocket connect succeed!")
  46. sys.publish("wsc_conack")
  47. end
  48. end)
  49. wsc:connect()
  50. -- 等待conack是可选的
  51. sys.waitUntil("wsc_conack")
  52. --local stat = wsc:ready()
  53. -- 定期发业务ping也是可选的, 但为了保存连接, 也为了继续持有wsc对象, 这里周期性发数据
  54. while true do
  55. wsc:send((json.encode({action="echo", msg=os.date()})))
  56. sys.wait(15000)
  57. -- 发送二进制帧, 2023.06.21 之后编译的固件支持
  58. -- wsc:send(string.char(0xA5, 0x5A, 0xAA, 0xF2), 1, 1)
  59. end
  60. wsc:close()
  61. wsc = nil
  62. end)
  63. -- 用户代码已结束---------------------------------------------
  64. -- 结尾总是这一句
  65. sys.run()
  66. -- sys.run()之后后面不要加任何语句!!!!!