main.lua 6.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202
  1. --[[
  2. socket客户端演示
  3. 提示:
  4. 1. socket支持多个连接的, 通常最多支持8个, 可通过不同的taskName进行区分
  5. 2. 支持与http/mqtt/websocket/ftp库同时使用, 互不干扰
  6. 3. 支持IP和域名, 域名是自动解析的, 但解析域名也需要耗时
  7. 4. 加密连接(TLS/SSL)需要更多内存, 这意味着能容纳的连接数会小很多, 同时也更慢
  8. TLS协议及加密套件
  9. TLS
  10. TLS 1.0 支持
  11. TLS 1.1 支持
  12. TLS 1.2 支持
  13. TLS 1.3 默认未开启, 未测试
  14. SSL 3.0, 默认禁用
  15. 加密套件请查询:https://wiki.luatos.com/chips/air780e/network.html#tls
  16. 如需使用ipv6, 请查阅 demo/ipv6, 本demo只涉及ipv4
  17. ]]
  18. -- LuaTools需要PROJECT和VERSION这两个信息
  19. PROJECT = "scdemo"
  20. VERSION = "1.0.0"
  21. log.info("main", PROJECT, VERSION)
  22. -- 一定要添加sys.lua !!!!
  23. sys = require("sys")
  24. sysplus = require("sysplus")
  25. libnet = require "libnet"
  26. -- Air780E的AT固件默认会为开机键防抖, 导致部分用户刷机很麻烦
  27. if rtos.bsp() == "EC618" and pm and pm.PWK_MODE then
  28. pm.power(pm.PWK_MODE, false)
  29. end
  30. if wdt then
  31. --添加硬狗防止程序卡死,在支持的设备上启用这个功能
  32. wdt.init(9000)--初始化watchdog设置为9s
  33. sys.timerLoopStart(wdt.feed, 3000)--3s喂一次狗
  34. end
  35. --=============================================================
  36. -- 测试网站 https://netlab.luatos.com/ 点击 打开TCP 获取测试端口号
  37. -- 要按实际情况修改
  38. local host = "112.125.89.8" -- 服务器ip或者域名, 都可以的
  39. local port = 45186 -- 服务器端口号
  40. local is_udp = false -- 如果是UDP, 要改成true, false就是TCP
  41. local is_tls = true -- 加密与否, 要看服务器的实际情况
  42. --=============================================================
  43. -- 处理未识别的网络消息
  44. local function netCB(msg)
  45. log.info("未处理消息", msg[1], msg[2], msg[3], msg[4])
  46. end
  47. -- 演示task
  48. local function sockettest()
  49. -- 等待联网
  50. sys.waitUntil("IP_READY")
  51. -- 时间同步
  52. socket.sntp()
  53. -- 开始正在的逻辑, 发起socket链接,等待数据/上报心跳
  54. local taskName = "sc"
  55. local topic = taskName .. "_txrx"
  56. log.info("topic", topic)
  57. local txqueue = {}
  58. --[[创建一个任务线程
  59. @param1 function 任务函数名,用于resume唤醒时调用
  60. @param2 string 任务名称,用于唤醒任务id
  61. @param3 function 接收到非目标消息时的回调函数
  62. @param4 any 任务函数fun的可变参数
  63. @return number 返回该任务的线程号
  64. ]]
  65. sysplus.taskInitEx(sockettask, taskName, netCB, taskName, txqueue, topic)
  66. while 1 do
  67. local result, tp, data = sys.waitUntil(topic, 30000)
  68. log.info("event", result, tp, data)
  69. if not result then
  70. -- 等很久了,没数据上传/下发, 发个日期心跳包吧
  71. table.insert(txqueue, os.date())
  72. sys_send(taskName, socket.EVENT, 0)
  73. elseif tp == "uplink" then
  74. -- 上行数据, 主动上报的数据,那就发送呀
  75. table.insert(txqueue, data)
  76. sys_send(taskName, socket.EVENT, 0)
  77. elseif tp == "downlink" then
  78. -- 下行数据,接收的数据, 从ipv6task来的
  79. -- 其他代码可以通过 sys.publish()
  80. log.info("socket", "收到下发的数据了", #data,"data:",data)
  81. end
  82. end
  83. end
  84. function sockettask(d1Name, txqueue, rxtopic)
  85. -- 打印准备连接的服务器信息
  86. log.info("socket", host, port, is_udp and "UDP" or "TCP", is_tls and "TLS" or "RAW")
  87. -- 准备好所需要的接收缓冲区
  88. local rx_buff = zbuff.create(1024)
  89. local netc = socket.create(nil, d1Name)
  90. socket.config(netc, nil, is_udp, is_tls)
  91. log.info("任务id", d1Name)
  92. while true do
  93. -- 连接服务器, 15秒超时
  94. log.info("socket", "开始连接服务器")
  95. sysplus.cleanMsg(d1Name)
  96. local result = libnet.connect(d1Name, 15000, netc, host, port)
  97. if result then
  98. log.info("socket", "服务器连上了")
  99. --向服务器发送数据
  100. libnet.tx(d1Name, 0, netc, "helloworld")
  101. else
  102. log.info("socket", "服务器没连上了!!!")
  103. end
  104. while result do
  105. -- 连接成功之后, 先尝试接收
  106. -- log.info("socket", "调用rx接收数据")
  107. local succ, param = socket.rx(netc, rx_buff)
  108. if not succ then
  109. log.info("服务器断开了", succ, param, ip, port)
  110. break
  111. end
  112. -- 如果服务器有下发数据, used()就必然大于0, 进行处理
  113. if rx_buff:used() > 0 then
  114. log.info("socket", "收到服务器数据,长度", rx_buff:used())
  115. local data = rx_buff:query() -- 获取数据
  116. sys.publish(rxtopic, "downlink", data)
  117. rx_buff:del()
  118. end
  119. -- log.info("libnet", "调用wait开始等待消息")
  120. -- 等待事件, 例如: 服务器下发数据, 有数据准备上报, 服务器断开连接
  121. result, param, param2 = libnet.wait(d1Name, 15000, netc)
  122. log.info("libnet", "wait", result, param, param2)
  123. if not result then
  124. -- 网络异常了, 那就断开了, 执行清理工作
  125. log.info("socket", "服务器断开了", result, param)
  126. break
  127. elseif #txqueue > 0 then
  128. -- 有待上报的数据,处理之
  129. while #txqueue > 0 do
  130. local data = table.remove(txqueue, 1)
  131. if not data then
  132. break
  133. end
  134. result,param = libnet.tx(d1Name, 15000, netc,data)
  135. log.info("libnet", "发送数据的结果", result, param)
  136. if not result then
  137. log.info("socket", "数据发送异常", result, param)
  138. break
  139. end
  140. end
  141. end
  142. -- 循环尾部, 继续下一轮循环
  143. end
  144. -- 能到这里, 要么服务器断开连接, 要么上报(tx)失败, 或者是主动退出
  145. libnet.close(d1Name, 5000, netc)
  146. -- log.info(rtos.meminfo("sys"))
  147. sys.wait(30000) -- 这是重连时长, 自行调整
  148. end
  149. end
  150. sys.taskInit(sockettest)
  151. -- 演示定时上报数据, 不需要就注释掉
  152. sys.taskInit(function()
  153. sys.wait(5000)
  154. while 1 do
  155. sys.publish("sc_txrx", "uplink", os.date())
  156. sys.wait(10000)
  157. end
  158. end)
  159. -- 演示uart数据上报, 不需要就注释掉
  160. if rtos.bsp() == "EC618" then
  161. uart.setup(1, 115200) -- 注意, 是UART1, 不是虚拟串口, 演示目的
  162. uart.on(1, "receive", function(id, len)
  163. while 1 do
  164. local s = uart.read(1, 1024)
  165. if #s == 0 then
  166. break
  167. end
  168. sys.publish("sc_txrx", "uplink", s)
  169. if #s == len then
  170. break
  171. end
  172. end
  173. end)
  174. end
  175. -- 用户代码已结束---------------------------------------------
  176. -- 结尾总是这一句
  177. sys.run()
  178. -- sys.run()之后后面不要加任何语句!!!!!